我有一个基于Blazor服务器的应用程序。我基本上在应用程序中为管理员显示数据库列。身份验证是使用Azure AD完成的,在startup.cs中我添加了
options.AddPolicy("AppAdmins", policy => policy.RequireRole("Admin", "SuperAdmin", "Owner"));
在主页上我有
<AuthorizeView Policy="AppAdmins">
<Authorized>
@Body
</Authorized>
<NotAuthorized>
You are not authorized to use this application.
</NotAuthorized>
</AuthorizeView>
这是有效的,现在对于特定的角色用户,我需要显示特定于角色的数据库列。如何访问Index.razor或Index.razon.cs中的角色以筛选字段?
我是Blazor和的新手。Net Core。
您可以在组件中注入AuthenticationStateProvider用户,检查他是否已通过身份验证,然后检索分配给他的角色。
@using System.Security.Claims
@using Microsoft.AspNetCore.Components.Authorization
@inject AuthenticationStateProvider AuthenticationStateProvider
var authState = await AuthenticationStateProvider.GetAuthenticationStateAsync();
var user = authState.User;
if (user.Identity.IsAuthenticated)
{
var identity = (ClaimsIdentity)user.Identity;
var roleClaims = identity.FindAll(identity.RoleClaimType);
foreach (var existingClaim in roleClaims)
{
// Do something with the roles...
}
}
else
{
// "The user is NOT authenticated.";
}