将AspNetIdentity与IdentityServer3一起使用时,User.Identity.Name始终为null

The*_*ian 7 asp.net asp.net-identity identityserver3

我一直试图用AspNetIdentity设置一个新的IdentityServer3几天了.我能够使用我现有的Identity DB登录,这一切都很好,但我永远无法获得包含数据的User.Identity.Name.我尝试过多次尝试添加自定义声明和范围以及向客户端添加范围.

最后,我加载了IdentityServer3示例存储库,并使用webforms客户端项目对其进行了测试,因为它已在其"关于"页面中使用了User.Identity.Name.

使用WebForms示例客户端+ AspNetIdentity示例服务器= User.Identity.Name始终为null使用带有Seq示例服务器的WebForms示例客户端+ SelfHost =带有数据的User.Identity.Name我尝试了其他所有填充User.Identity的示例宿主项目.Name值就好了.

现在,在客户端,我写了一个解决方法来提取'preferred_username'声明值并用它设置'name'声明.

var id = new claimsIdentity(n.AuthenticationTicket.Identity.AuthenticationType);
id.AddClaims(userInfoResponse.GetClaimsIdentity().Claims);

//set the User.Identity.Name value
var name = id.Claims.Where(x => x.Type == "name").Select(x => x.Value).FirstOrDefault() ??
           id.Claims.Where(x => x.Type == "preferred_username").Select(x => x.Value).FirstOrDefault();
id.AddClaim(new Claim("name", name));
Run Code Online (Sandbox Code Playgroud)

我的问题是:

  1. 为什么AspNetIdentity包默认不填写?
  2. 我需要在服务器端进行哪些更改,以便我不需要更改客户端?

Dan*_*ini 0

在 IdentityServer4 上,您可以在服务器上实现 IProfileService 并在 GetProfileDataAsync 中添加声明

public class AspNetIdentityProfileService : IProfileService
{
    protected UserManager<ApplicationUser> _userManager;

    public AspNetIdentityProfileService(UserManager<ApplicationUser> userManager)
    {
        _userManager = userManager;
    }

    public Task GetProfileDataAsync(ProfileDataRequestContext context)
    {
        //Processing
        var user = _userManager.GetUserAsync(context.Subject).Result;

        var claims = new List<Claim>
        {
            new Claim(ClaimTypes.Name, user.UserName),
        };

        context.IssuedClaims.AddRange(claims);

        //Return
        return Task.FromResult(0);
    }

    public Task IsActiveAsync(IsActiveContext context)
    {
        //Processing
        var user = _userManager.GetUserAsync(context.Subject).Result;

        context.IsActive = (user != null) && ((!user.LockoutEnd.HasValue) || (user.LockoutEnd.Value <= DateTime.Now));

        //Return
        return Task.FromResult(0);
    }
}
Run Code Online (Sandbox Code Playgroud)

然后将“AddProfileService()”添加到您的ConfigureServices 方法中。

services.AddIdentityServer(...)
    ...
    .AddProfileService<AspNetIdentityProfileService>();
Run Code Online (Sandbox Code Playgroud)