重定向至"403 Blazor WebAssembly中的Forbidden组件"诊断树



我目前正在开发.NET Standard 2.1 Blazor WebAssembly Hosted应用程序。

在我的身份验证方案中,我使用用户角色

如果用户不在角色中,即管理员,我希望将所有用户重定向到<ForbiddenView />

如果能在应用程序中的一个位置处理这个问题,那就太好了。

  • 我的App.razor如下所示:
<CascadingAuthenticationState>
<Router AppAssembly="@typeof(Program).Assembly">
<Found Context="routeData">
<AuthorizeRouteView RouteData="@routeData">
<Authorizing>
<p>Authorizing...</p>
</Authorizing>
<NotAuthorized>
@if (!context.User.Identity.IsAuthenticated)
{
// User is not authenticated - forward to login view
<LoginView />
}
else if(context.User.Identity.IsAuthenticated && context.User.Identity.NotInRole) // .NotInRole does not exist!!
{
// 403 - User is authenticated, but not in a specific role i.e. admin to view a page in my app. The server understood the request, but is refusing to fulfill it.
<ForbiddenView />
}
else
{
// 401 - Login of my user happend - the request already includes Authorization credentials.
<NotAuthorizedView />
}
</NotAuthorized>
</AuthorizeRouteView>
</Found>
<NotFound>
<NotFoundView />
</NotFound>
</Router>
</CascadingAuthenticationState>

你知道如何集中处理Blazor WebAssembly中的403错误吗?

你对如何处理Blazor WebAssembly上的403错误有什么建议吗?

尝试在不同的上下文中使用AuthorizeView:

<CascadingAuthenticationState>
<Router AppAssembly="@typeof(Program).Assembly">
<Found Context="routeData">
<AuthorizeRouteView RouteData="@routeData">
<Authorizing>
<p>Authorizing...</p>
</Authorizing>
<NotAuthorized>
<AuthorizeView Context="authenticated">
<Authorized Context="authenticated">
<AuthorizeView Roles="WhatEver" Context="role">
<Authorized Context="role">
<NotAuthorizedView />
</Authorized>
<NotAuthorized Context="role">
<ForbiddenView />
</NotAuthorized>
</AuthorizeView>
</Authorized>
<NotAuthorized Context="authenticated">
<RedirectToLogin />
</NotAuthorized>
</AuthorizeView>
</NotAuthorized>
</AuthorizeRouteView>
</Found>
<NotFound>
<NotFoundView />
</NotFound>
</Router>
</CascadingAuthenticationState>

!context.User.IsInRole("WhatEver");

如果您特别需要NotInRole:

public static bool NotInRole(this ClaimsPrincipal claimsPrincipal) 
=> claimsPrincipal.Claims.All(c => c.Type != "role");

相关内容

  • 没有找到相关文章

最新更新