我正在使用mvc5 + c#,我通过外部登录(facebook,google,...)为我的用户提供了登录我网站的选项。
我正在尝试将Microsoft Live添加为新的提供商。但是,我没有看到任何选项来获取已连接用户的电子邮件地址。
当某些微软用户连接时,我正在获取这些声明(“KEY | VALUE”):
http://schemas.xmlsoap.org/ws/2005/05/identity/claims/nameidentifier | *****************
http://schemas.xmlsoap.org/ws/2005/05/identity/claims/name | test
http://schemas.microsoft.com/accesscontrolservice/2010/07/claims/identityprovider | ASP.NET Identity
http://schemas.xmlsoap.org/ws/2005/05/identity/claims/nameidentifier | **************
http://schemas.xmlsoap.org/ws/2005/05/identity/claims/name | ****************
urn:microsoftaccount:id | ****************
urn:microsoftaccount:name | ****************
urn:microsoftaccount:access_token | **************************************************************
使用此信息可以选择获取用户的电子邮件地址吗?
答案 0 :(得分:12)
是的,有。经过几个小时的尝试,我设法让它像这样工作:
startup.Auth.cs中的代码
var ms = new Microsoft.Owin.Security.MicrosoftAccount.MicrosoftAccountAuthenticationOptions();
ms.Scope.Add("wl.emails");
ms.Scope.Add("wl.basic");
ms.ClientId = "xxxxxxxxxxxxxxxxxxxxxx";
ms.ClientSecret = "yyyyyyyyyyyyyyyyyyyyy";
ms.Provider = new Microsoft.Owin.Security.MicrosoftAccount.MicrosoftAccountAuthenticationProvider()
{
OnAuthenticated = async context =>
{
context.Identity.AddClaim(new System.Security.Claims.Claim("urn:microsoftaccount:access_token", context.AccessToken));
foreach (var claim in context.User)
{
var claimType = string.Format("urn:microsoftaccount:{0}", claim.Key);
string claimValue = claim.Value.ToString();
if (!context.Identity.HasClaim(claimType, claimValue))
context.Identity.AddClaim(new System.Security.Claims.Claim(claimType, claimValue, "XmlSchemaString", "Microsoft"));
}
}
};
app.UseMicrosoftAccountAuthentication(ms);
AccountController.cs中的代码,在函数ExternalLoginCallback中检索电子邮件地址:
string Email = string.Empty;
var externalIdentity = await AuthenticationManager.GetExternalIdentityAsync(DefaultAuthenticationTypes.ExternalCookie);
var emailClaim = externalIdentity.Claims.FirstOrDefault(x => x.Type.Equals(
"http://schemas.xmlsoap.org/ws/2005/05/identity/claims/emailaddress",
StringComparison.OrdinalIgnoreCase));
Email = emailClaim == null ? null : emailClaim.Value;
答案 1 :(得分:0)
对于在您的网站上添加Microsoft登录信息而遇到此问题的任何人:
我发现我只能获取Microsoft Work / School帐户的电子邮件地址。我使用@ gmail.com地址创建了一个Microsoft帐户,另一个是@ outlook.com。当我查询他们的信息时,两者都没有关联的任何电子邮件信息。但是,对于符合条件的地址,您可以通过执行GET请求来获取电子邮件信息:
https://apis.live.net/v5.0/me?access_token=ACCESS_TOKEN
ACCESS_TOKEN是经过身份验证的用户将向您提供的地方*。有关此API的更多信息,您可以看到以下链接:https://msdn.microsoft.com/en-us/library/office/dn659736.aspx
基本上,调用Microsoft Live API(apis.live.net)将为您提供用户已授予您访问权限的信息(因此,如果您在应用中启用了wl.emails范围,则应该看他们的电子邮件地址。)
*或者,当用户使用Microsoft登录进入您的站点时,他们对您站点的请求将包含一个标题,其中包含访问令牌和可能的电子邮件地址(电子邮件地址位于标题“X-MS-”下) CLIENT-PRINCIPAL-NAME“,访问令牌也在”X-MS-TOKEN-MICROSOFT-ACCESS-TOKEN“下的HTTP头中。)