如何向 Blazor WebAssembly 3.2.0 Preview 3 应用程序添加其他声明

use*_*866 7 blazor-client-side

我创建了一个 Asp.Net Core 托管的 Blazor webassembly 3.2.0 Preview 3 应用程序,其中包含应用程序内帐户的身份验证选项。然后我向 ApplicationUser 类添加了一些额外的属性,并将这些更改迁移到数据库。然后我实现了一个自定义声明工厂,如下所示:

public class MyCustomUserClaimsPrincipalFactory : UserClaimsPrincipalFactory<ApplicationUser>
{
    public MyCustomUserClaimsPrincipalFactory(
        UserManager<ApplicationUser> userManager,
        IOptions<IdentityOptions> optionsAccessor)
            : base(userManager, optionsAccessor)
    {
    }

    protected override async Task<ClaimsIdentity> GenerateClaimsAsync(ApplicationUser user)
    {
        var identity = await base.GenerateClaimsAsync(user);
        identity.AddClaim(new Claim(ClaimTypes.GivenName, user.FirstName ?? string.Empty));
        .....

        return identity;
    }
}
Run Code Online (Sandbox Code Playgroud)

并在服务器应用程序中注册声明工厂,如下所示:

services.AddDefaultIdentity<ApplicationUser>(options => options.SignIn.RequireConfirmedAccount = true)
            .AddEntityFrameworkStores<ApplicationDbContext>()
            .AddClaimsPrincipalFactory<MyCustomUserClaimsPrincipalFactory>();
Run Code Online (Sandbox Code Playgroud)

但是,当我在客户端 Web 应用程序组件中列出声明时,我没有看到我在自定义声明工厂中添加的任何其他声明。我用来列出索赔的代码是:

<AuthorizeView>
   <Authorized>
    <ul>
        @foreach (var claim in context.User.Claims)
        {
            <li><span>@claim.Type</span><span>@claim.Value</span></li>
        }
    </ul>
   </Authorized>
</AuthorizeView>
Run Code Online (Sandbox Code Playgroud)

我确认正在调用声明工厂代码。如何在客户端 Web 应用程序中获取其他声明?

编辑:我甚至用ClaimsTransformer(如建议尝试在这里),但我仍然没有看到其他声明

小智 1

我按照 dfkeenan 在此线程上的说明进行操作: https://github.com/dotnet/aspnetcore/issues/20887

我添加了一个 ProfileService,在其中添加了我需要的声明(CompanyName、CompanyID)

public class ProfileService : IProfileService
{
    public ProfileService()
    {
    }

    public Task GetProfileDataAsync(ProfileDataRequestContext context)
    {
        var nameClaim = context.Subject.FindAll(JwtClaimTypes.Name);
        context.IssuedClaims.AddRange(nameClaim);

        var roleClaims = context.Subject.FindAll(JwtClaimTypes.Role);
        context.IssuedClaims.AddRange(roleClaims);
        context.IssuedClaims.AddRange(context.Subject.FindAll("CompanyName"));
        context.IssuedClaims.AddRange(context.Subject.FindAll("CompanyId"));

        return Task.CompletedTask;
    }

    public Task IsActiveAsync(IsActiveContext context)
    {
        return Task.CompletedTask;
    }
}
Run Code Online (Sandbox Code Playgroud)

然后注册

services.AddTransient<IProfileService, ProfileService>();

在配置服务上