2014-11-25 48 views
4

Visual Studio-为AspNet Identity生成一堆代码,即LoginController和ManageController。在ManageController有下面的代码:AspNet Identity使用同一电子邮件进行多个外部登录

[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. 用户与电子邮件签署了谷歌加:[email protected]
  2. 用户使用相同的电子邮件注册Facebook。
  3. 现在,由于此例外情况,他们无法在应用程序的单个本地帐户下“链接”这两个帐户。

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

回答

2

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

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

哪里manager是的UserManager类的一个实例。

相关问题