Blazor 使用 Azure AD 身份验证允许匿名访问

m.t*_*ett 7 authentication azure azure-active-directory blazor blazor-server-side

我目前正在编写一个(服务器端)Blazor 应用程序,其中包含默认的 AzureAD 身份验证。

这对于经过身份验证的用户来说效果很好 - 挑战入口 ( _Host.cshtml) 文件,重定向,然后在经过身份验证后返回。

我需要有几个页面不需要身份验证 - 我不希望用户受到质询并重定向到 Microsoft。

这样做的正确方法是什么?我已经尝试过AllowAnonymousAttribute剃刀AllowAnonymousToPage页面选项,似乎没有什么可以阻止挑战。

任何帮助将不胜感激!

以下是我的身份验证设置(ConfigureServices):

public void ConfigureServices(IServiceCollection services)
{
    services.AddAuthentication(AzureADDefaults.AuthenticationScheme)
        .AddAzureAD(options => Configuration.Bind("AzureAd", options));

    services.AddControllersWithViews(options =>
{
    var policy = new AuthorizationPolicyBuilder()
        .RequireAuthenticatedUser()
        .Build();
    options.Filters.Add(new AuthorizeFilter(policy));
});

    services.AddRazorPages();
    services.AddServerSideBlazor();
    services.AddTelerikBlazor();
}
Run Code Online (Sandbox Code Playgroud)

然后是配置中的相应部分:

app.UseAuthentication();
app.UseAuthorization();

app.UseEndpoints(endpoints =>
{
    endpoints.MapControllers();
    endpoints.MapBlazorHub();
    endpoints.MapFallbackToPage("/_Host");
});
Run Code Online (Sandbox Code Playgroud)

Lar*_*Dev 8

我发现我要做的是将以下内容添加到 _Hosts.cshtml

@using Microsoft.AspNetCore.Authorization
@attribute [AllowAnonymous]
Run Code Online (Sandbox Code Playgroud)

一旦我这样做了,默认情况下任何页面都不再需要此授权,然后我可以将其添加到我想要需要它的页面。

例如,如果您想保护 Counter.razor 页面,只需在顶部添加一个 Authorize 属性:

@attribute [Authorize]
Run Code Online (Sandbox Code Playgroud)

因此,现在如果您尝试访问计数器页面,您将收到一条“未授权”消息。

如果要在用户未登录时删除计数器链接,请修改 NavMenu.razor 并用以下内容包围计数器链接<AuthorizeView> </AuthorizeView>

<AuthorizeView>
    <li class="nav-item px-3">
        <NavLink class="nav-link" href="counter">
            <span class="oi oi-plus" aria-hidden="true"></span> Counter
        </NavLink>
    </li>
</AuthorizeView> 
Run Code Online (Sandbox Code Playgroud)

理想情况下,我希望只选择退出索引页面的授权,并默认保护其他所有内容,但我找不到一种方法来使其发挥作用。如果我尝试将其添加@attribute [AllowAnonymous]到 Index.razor 页面,它似乎会忽略它。

  • 感谢您的回答@LarryDev,我发现删除 AuthorizeFilter (在 Startup.cs 中)特别是“RequireAuthenticatedUser”方法,因为这将其设置为站点范围的方法。然后只需将“AuthorizeAttribute”放在每个 Razor **页面**上(路由中不使用组件)。这样,__Hosts 页面上就不需要 `AllowAnonymousAttribute`。 (2认同)