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)
{
...
}
}
Run Code Online (Sandbox Code Playgroud)
我对此代码的问题是,UserManager.AddLoginAsync()当添加具有现有电子邮件地址的外部登录时会引发异常.但是,这似乎是一个有效的场景:
如何处理这种情况并添加两个帐户?这样做有什么问题吗?
您可以像这样禁用唯一电子邮件的要求:
manager.UserValidator = new UserValidator<ApplicationUser>(manager)
{
RequireUniqueEmail = false
};
Run Code Online (Sandbox Code Playgroud)
其中manager是 UserManager 类的实例。
| 归档时间: |
|
| 查看次数: |
1050 次 |
| 最近记录: |