Visual Studio-为AspNet Identity生成一堆代码,即LoginController和ManageController。在管理控制器中,有以下代码:
[HttpGet, Route("Manage/LinkLoginCallback")]
public async Task<ActionResult> LinkLoginCallback(string returnUrl)
{
ExternalLoginInfo loginInfo = await AuthenticationManager.GetExternalLoginInfoAsync(XsrfKey, User.Identity.GetUserId());
...
var result = await UserManager.AddLoginAsync(User.Identity.GetUserId(), loginInfo.Login);
if (result.Succeeded)
{
...
}
}
我使用此代码遇到的问题是,当添加具有现有电子邮件地址的外部登录时,UserManager.AddLoginAsync()
会引发异常。但是,这似乎是一个有效的方案:
- 用户通过电子邮件注册了Google Plus:user-email@gmail.com
- 用户使用相同的电子邮件注册Facebook。
- 现在,由于此异常,他们无法在我的应用程序中的单个本地帐户下"链接"两个帐户。
如何处理这种情况并添加两个帐户?这样做有什么问题吗?
您可以禁用唯一电子邮件的要求,如下所示:
manager.UserValidator = new UserValidator<ApplicationUser>(manager)
{
RequireUniqueEmail = false
};
其中manager
是用户管理器类的实例。