MVC oAuth登录-如何确定他们使用哪个社交帐户登录



我已经在我的MVC5网站上实现了Facebook和Twitter登录,一切都很好。

我想做的似乎很简单,但我不确定如何做。

我可以用获取登录用户的用户名

System.Web.HttpContext.Current.User.Identity.Name

然而,我想知道该用户是否使用Facebook或Twitter以及相关社交网络的ProviderKey登录。

希望这很容易做到

谢谢。

您可以使用以下方法获取所有外部登录信息。

private ApplicationUserManager _userManager;
public ApplicationUserManager UserManager
{
    get
    {
        return _userManager ?? HttpContext.GetOwinContext().GetUserManager<ApplicationUserManager>();
    }
    private set
    {
        _userManager = value;
    }
}

在您的行动中:

var getExternalLoginInfor = UserManager.GetLogins(User.Identity.GetUserId());

希望这能有所帮助。

可以从AuthenticationManager的扩展方法GetExternalLoginInfo中获取。

var loginInfo = AuthenticationManager.GetExternalLoginInfo();
if (loginInfo != null)
{
     var externalProvider = loginInfo.Login.LoginProvider;
}

编辑:在您的ApplicationSignInManager : SignInManager类重写方法SignInAsync

在那里,您可以外部登录信息并将其添加为索赔

public override async Task SignInAsync(User user, bool isPersistent, bool rememberBrowser)
{
    var userIdentity = await CreateUserIdentityAsync(user); 
    //
    var logininfo = AuthenticationManager.GetExternalLoginInfo();
    userIdentity.AddClaim(new Claim("ExternalLoginProvider", logininfo.Login.LoginProvider));
    //
    AuthenticationManager.SignOut(DefaultAuthenticationTypes.ExternalCookie, DefaultAuthenticationTypes.TwoFactorCookie);
    if (rememberBrowser)
    {
         var rememberBrowserIdentity = AuthenticationManager.CreateTwoFactorRememberBrowserIdentity(ConvertIdToString(user.Id));
         AuthenticationManager.SignIn(new AuthenticationProperties { IsPersistent = isPersistent }, userIdentity, rememberBrowserIdentity);
    }
    else
    {
         AuthenticationManager.SignIn(new AuthenticationProperties { IsPersistent = isPersistent }, userIdentity);
    }
}

然后你可以这样访问它:

var identity = (ClaimsIdentity)User.Identity;
var loginProvide = identity.FindFirst("ExternalLoginProvider").Value;

相关内容

  • 没有找到相关文章

最新更新