后索赔一期工程已更新从MVC 4 MVC 5,因为新的使用Visual Studio 2015年这是不正确编译剃刀的观点(这是东西是被记录在案微软并没有这个问题)。 我们使用跨项目的实用程序类来检索存储在身份声明中的值。问题与迁移项目MVC5,意外调用GetRolesForUser
在这一类中,有人做了一个电话:
System.Security.Claims.ClaimsPrincipal.Current.Claims.ToList()
这是在以前的MVC4版本的工作,但迁移所有MVC5所需的NuGet包后,这个特定的呼叫引发以下错误:
An exception of type 'System.ArgumentNullException' occurred in System.Web.Providers.dll but was not handled in user code
Value cannot be null.
Parameter name : username
System.Web.Providers.DefaultRoleProvider.GetRolesForUser(String username) +183 System.Web.Security.RolePrincipal.GetRoles() +215
System.Web.Security.d__1.MoveNext() +58
System.Security.Claims.d__1.MoveNext() +253
System.Security.Claims.d__1.MoveNext() +209
System.Collections.Generic.List1..ctor(IEnumerable
1 collection) +445 System.Linq.Enumerable.ToList(IEnumerable`1 source) +58
我做了一个foreach()上收集,而是和它就像毕竟自定义的索赔它达到了一个意外的结束,或者它试图找回从GetRoleForUser的事情,我不知道为什么。
如果任何人有一个提示,如果需要,我可以提供更多的细节。
安装该MVC项目的Web.config的:
<modules>
<add name="WSFederationAuthenticationModule" type="System.IdentityModel.Services.WSFederationAuthenticationModule, System.IdentityModel.Services, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" preCondition="managedHandler" />
<add name="SessionAuthenticationModule" type="System.IdentityModel.Services.SessionAuthenticationModule, System.IdentityModel.Services, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" preCondition="managedHandler" />
<add name="ClaimsAuthorizationModule" type="System.IdentityModel.Services.ClaimsAuthorizationModule, System.IdentityModel.Services, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" preCondition="managedHandler" />
<remove name="FormsAuthentication" />
</modules>
....
<system.identityModel>
<identityConfiguration>
<audienceUris>
<add value="http://localhost:58663/" />
</audienceUris>
<securityTokenHandlers>
<add type="System.IdentityModel.Services.Tokens.MachineKeySessionSecurityTokenHandler, System.IdentityModel.Services, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
<remove type="System.IdentityModel.Tokens.SessionSecurityTokenHandler, System.IdentityModel, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
</securityTokenHandlers>
<certificateValidation certificateValidationMode="None" />
<issuerNameRegistry type="System.IdentityModel.Tokens.ValidatingIssuerNameRegistry, System.IdentityModel.Tokens.ValidatingIssuerNameRegistry">
<authority name="QuadraSTS">
<keys>
<add thumbprint="XXXHIDDENXXX" />
</keys>
<validIssuers>
<add name="QuadraSTS" />
</validIssuers>
</authority>
</issuerNameRegistry>
<claimsAuthorizationManager type="ClaimsBasedAuthorization.AuthorizationManager,QuadraBox" />
</identityConfiguration>
</system.identityModel>
<system.identityModel.services>
<federationConfiguration>
<cookieHandler requireSsl="false" persistentSessionLifetime="1.0:0:0" path="/" />
<wsFederation passiveRedirectEnabled="true" persistentCookiesOnPassiveRedirects="true" issuer="http://something:97/QuadraSTSBeta/" realm="http://localhost:58663/" requireHttps="false" />
</federationConfiguration>
</system.identityModel.services>