3

我正在使用 WIF 登录我的应用程序。一切似乎都很好(日志记录、重定向到站点等),但是当我尝试User.Identity.Name在我的 cod 中使用时,异常被抛出 -User为空。任何想法我做错了什么?我在 VS 2012 上工作。web.config 中生成的部分如下所示:

  <system.identityModel>
    <identityConfiguration>
      <audienceUris>
        <add value="http://xxx/" />
      </audienceUris>     
      <issuerNameRegistry type="System.IdentityModel.Tokens.ConfigurationBasedIssuerNameRegistry, System.IdentityModel, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
        <trustedIssuers>
          <add thumbprint="yyyy" name="https://zzz" />
        </trustedIssuers>
      </issuerNameRegistry>
    </identityConfiguration>
  </system.identityModel>

和:

  <system.identityModel.services>
    <federationConfiguration>
      <cookieHandler requireSsl="false" />
      <wsFederation passiveRedirectEnabled="true" issuer="https://zzz/Secure/FederatedLogin.ashx" realm="http://xxx" requireHttps="false" />          
    </federationConfiguration>        
  </system.identityModel.services>
4

3 回答 3

2

检查 STS 是否包含用户的名称声明,否则 User.Identity.Name 将为空。

于 2013-03-08T23:09:10.947 回答
2

使用 WIF 时,您应该使用 Thread.CurrentPrincipal.Identity.Name 而不是 User.Identity.Name。

在此处阅读更多信息:http: //msdn.microsoft.com/en-us/magazine/ff872350.aspx以了解有关 Windows Identity Foundation 的更多信息

于 2013-02-28T15:20:02.767 回答
0

Instead I used:

namespace System.Security.Claims
{
    public static class System_Security_Claims_Extensions
    {
        public static string getName(this ClaimsIdentity ci)
        {
            foreach (Claim c in ci.Claims)
            {
                if (c.Type == ClaimTypes.Name)
                {
                    return c.Value;
                }
            }
            return string.Empty;
        }
    }
}

And used in this context
((ClaimsIdentity)Thread.CurrentPrincipal.Identity).getName()

于 2014-05-01T18:11:01.870 回答