Visual Studio - 为AspNet Identity生成一堆代码,即LoginController和ManageController。在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()
在添加具有现有电子邮件地址的外部登录时会引发异常。但是,这似乎是一个有效的方案:
如何处理这种情况并添加两个帐户?这样做有什么问题吗?
答案 0 :(得分:2)
您可以停用以下唯一电子邮件的要求:
manager.UserValidator = new UserValidator<ApplicationUser>(manager)
{
RequireUniqueEmail = false
};
其中manager
是UserManager类的实例。