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”,或者使用这种方法会优雅一点。不过当我升级到abp4.3.2后就不需要配置了
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 : IUserClaimsPrincipalFactory。
好了目前就是这样。欢迎评论跟交流。