AspNet Identity使用相同的电子邮件进行多次外部登录

par*_*ent 5 asp.net-identity

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()当添加具有现有电子邮件地址的外部登录时会引发异常.但是,这似乎是一个有效的场景:

  1. 用户通过电子邮件注册Google Plus:user-email@gmail.com
  2. 用户使用相同的电子邮件注册Facebook.
  3. 现在,由于此异常,他们无法在我的应用程序中的单个本地帐户下"链接"这两个帐户.

如何处理这种情况并添加两个帐户?这样做有什么问题吗?

Riw*_*wen 3

您可以像这样禁用唯一电子邮件的要求:

    manager.UserValidator = new UserValidator<ApplicationUser>(manager)
        {
            RequireUniqueEmail = false
        }; 
Run Code Online (Sandbox Code Playgroud)

其中manager是 UserManager 类的实例。