abp vnext将用户名添加到token中


1.最无脑,不推荐使用。就是重写此类,然后注入context.Services.AddTransient<IProfileService, ProfileService>();  你需要什么要加什么

public class ProfileService: IProfileService
    {
        private readonly UserManager<IdentityUser> _userManager; 
        public ProfileService(UserManager<IdentityUser> userManager)
        {
            _userManager = userManager;
        }

        public async Task GetProfileDataAsync(ProfileDataRequestContext context)
        {
            var user = await _userManager.GetUserAsync(context.Subject);

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

            context.IssuedClaims.AddRange(claims);
        }
}

  

2.如果只要用户的name信息的话跟一些user上有的信息,可以修改seeddata种子数据(DoMain层的seed类,如果微服务在authService) ,注释的为添加的,其他的本来就有了。

private async Task CreateApiResourcesAsync()
        {
            var commonApiUserClaims = new[]
            {
                "email",
                "email_verified",
                "given_name",//Name
                "name",
                "family_name",//surName
                "phone_number",
                "phone_number_verified",
                "role"
            };

            await CreateApiResourceAsync("BookStore", commonApiUserClaims);
        }

  

然后需要全局配置一个 AbpClaimTypes.Name = "given_name",或者使用这种方法会优雅一点

 Configure<AbpClaimsMapOptions>(options =>
            {
                options.Maps.Add("given_name", () => AbpClaimTypes.Name);
                options.Maps.Add("name", () => AbpClaimTypes.UserName);
            });

  

3.https://www.jianshu.com/p/a22ed53bfbf4 可以查看这位博主的方式。

接下来就可以去获取token了 然后可以使用jwt工具直接查看,如果没显示可能你的用户名为null。
我去稍微看了一下源码,本质上还是从ClaimsPrincipal上使用的,所以abp.identityservice中的继承了IUserClaimsPrincipalFactory。
AbpUserClaimsFactory<TUser> : IUserClaimsPrincipalFactory<TUser>。

好了目前就是这样。欢迎评论跟交流。


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM