您不能UserManager
从 WebAssembly Blazor 应用程序中使用它,因为它在浏览器上运行。一般来说,您不能在 WebAssembly Blazor 应用程序中使用与数据库访问相关的对象。相反,您通常会创建一个 Web Api 操作方法,并使用 Fetch API (HttpClient) 访问这些方法。
您想从 User 对象中提取什么价值?
是什么Nombre
?
不管是什么Nombre
,您都可以将此值 ( Nombre
) 添加为声明并从authState.User
更新
首先,您应该创建一个名为 ApplicationUserClaimsPrincipalFactory 的服务类,该类用于将表列的值从 Users 表转换为添加到传递给 Blazor 客户端的 ClaimsPrincipal 对象的声明。
(服务器应用程序)ApplicationUserClaimsPrincipalFactory.cs
using AuthenticationStateProviderCustomClaims.Server.Models;
using Microsoft.AspNetCore.Identity;
using Microsoft.Extensions.Options;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Security.Claims;
using System.Threading.Tasks;
public class ApplicationUserClaimsPrincipalFactory :
UserClaimsPrincipalFactory<ApplicationUser>
{
public ApplicationUserClaimsPrincipalFactory(UserManager<ApplicationUser> userManager,
IOptions<IdentityOptions> optionsAccessor) : base(userManager, optionsAccessor)
{
}
protected override async Task<ClaimsIdentity>
GenerateClaimsAsync(ApplicationUser user)
{
ClaimsIdentity claims = await
base.GenerateClaimsAsync(user);
claims.AddClaim(new Claim("name", user.Nombre));
return claims;
}
}
启动.ConfigureServices
将以下内容放在 .AddDBContext 下方:
services.AddScoped<ApplicationUserClaimsPrincipalFactory>();
services.AddDefaultIdentity<ApplicationUser>(options => options.SignIn.RequireConfirmedAccount = true)
.AddRoles<IdentityRole>()
.AddEntityFrameworkStores<ApplicationDbContext>()
.AddClaimsPrincipalFactory<ApplicationUserClaimsPrincipalFactory>();
services.AddIdentityServer() .AddApiAuthorization<ApplicationUser, ApplicationDbContext>(options => {
// Note: This settings may be superfluous as the name claim
// is added by default.
options.IdentityResources["openid"].UserClaims.Add("name");
options.ApiResources.Single().UserClaims.Add("name");
});
services.AddAuthentication().AddIdentityServerJwt();
客户端
运行此代码,看看它是否工作......如果没有,请发布完整的错误报告
索引剃刀
@page "/"
@using System.Security.Claims
@using Microsoft.AspNetCore.Components.Authorization
@inject AuthenticationStateProvider AuthenticationStateProvider
<p>@_authMessage</p>
@if (_claims != null && _claims.Count() > 0)
{
<ul>
@foreach (var claim in _claims)
{
<li>@claim.Type: @claim.Value</li>
}
</ul>
}
<p>@_nombreMessage</p>
@code {
private string _authMessage;
private string _nombreMessage;
private IEnumerable<Claim> _claims = Enumerable.Empty<Claim>();
private async Task GetClaimsPrincipalData()
{
var authState = await AuthenticationStateProvider.GetAuthenticationStateAsync();
var user = authState.User;
if (user.Identity.IsAuthenticated)
{
_authMessage = $"{user.Identity.Name} is authenticated.";
_claims = user.Claims;
_nombreMessage =
$"Nombre: {user.FindFirst(c => c.Type == ClaimTypes.Name)?.Value}";
}
else
{
_authMessage = "The user is NOT authenticated.";
}
}
protected override async Task OnInitializedAsync()
{
await GetClaimsPrincipalData();
}
}