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

时间:2014-11-25 04:24:45

标签: 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) 
        {
            ...
        }
    }

我对此代码的问题是,UserManager.AddLoginAsync()在添加具有现有电子邮件地址的外部登录时会引发异常。但是,这似乎是一个有效的方案:

  1. 用户通过电子邮件注册Google Plus:user-email@gmail.com
  2. 用户使用相同的电子邮件注册Facebook。
  3. 现在他们不能&#34; Link&#34;由于此例外,我的应用程序中的两个帐户都在一个本地帐户下。
  4. 如何处理这种情况并添加两个帐户?这样做有什么问题吗?

1 个答案:

答案 0 :(得分:2)

您可以停用以下唯一电子邮件的要求:

    manager.UserValidator = new UserValidator<ApplicationUser>(manager)
        {
            RequireUniqueEmail = false
        }; 

其中manager是UserManager类的实例。