我正在开发一个MVC4应用程序,它使用ADFS验证corp域用户,我已经编写了代码,我得到了如下错误,我没有得到索赔吗?
System.InvalidCastException:无法将'System.Security.Claims.ClaimsPrincipal‘类型的对象强制转换为'Microsoft.IdentityModel.Claims.IClaimsPrincipal'.类型
public ActionResult Index()
{
try
{
IClaimsPrincipal principal = (IClaimsPrincipal)Thread.CurrentPrincipal;
IClaimsIdentity identity = (IClaimsIdentity)principal.Identity;
if (String.IsNullOrEmpty(identity.Claims[0].Value.Split('@')[0]))
{
ViewData["Message"] = string.Format("You are email is :{0}", identity.Claims[0].Value.Split('@')[0]);
}
else
{
ViewData["Message"] = "You are not getting any claims";
}
}
catch (Exception ex)
{
ViewData["Message"] = "Something wrong.";
}
return View();
}发布于 2014-03-11 00:59:53
你观察到的是.NET 3.5WIF3.5WIF4 (Microsoft.IdentityModel)和WIF4.0 (System.IdentityModel & System.Security)的混合结果。我的建议是:
<代码>H19在Web.Config中修复对Microsoft.IdentityModel的引用<代码>H210<代码>G211
在执行此操作之前,请备份您的项目,因为如果您以前没有这样做过,您可能会出现很多错误,并且代码无法正常工作。但主要的想法是,你必须摆脱所有和任何Microsoft.IdentityModel引用,这样你就会变得很好。
发布于 2014-04-18 23:09:45
我能够按照astaykov的建议解决这个问题,并且我像下面这样修改了代码。
using System.Security.Claims;
var identity = User.Identity as ClaimsIdentity;
foreach (var claim in identity.Claims)
{
if (claim.Type.Contains("EmailAddress"))
{
ViewBag.EmailName = claim.Value;
}
}https://stackoverflow.com/questions/22304869
复制相似问题