我已经在我的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;