在 ASP.NET Core 3 中设置身份验证回退策略时,允许匿名访问健康检查端点

wxt*_*wxt 13 .net c# asp.net-web-api asp.net-core asp.net-core-3.0

asp.net core 3 允许设置FallbackPolicy以在默认情况下使端点安全:

            services.AddAuthorization(options =>
            {
                options.FallbackPolicy = new AuthorizationPolicyBuilder()
                    .RequireAuthenticatedUser()
                    .Build();
            });
Run Code Online (Sandbox Code Playgroud)

这是一个很棒的功能,但我也有一个HealthCheck端点,现在需要授权。

            services.AddHealthChecks();
            [...]
            app.UseEndpoints(endpoints => {
                endpoints.MapHealthChecks("/health");
                endpoints.MapControllers();
            });
Run Code Online (Sandbox Code Playgroud)

如何允许匿名访问 HealthCheck 端点(无身份验证或授权)?

小智 24

我遇到了完全相同的问题,所以我希望这有助于作为一种更令人满意的实现方式:

        app.UseEndpoints(endpoints =>
        {
            endpoints.MapDefaultControllerRoute().RequireAuthorization();

            endpoints.MapHealthChecks("/health").WithMetadata(new AllowAnonymousAttribute());

        });
Run Code Online (Sandbox Code Playgroud)


Fel*_*lix 8

从 .NET 5 开始,有一个新的更清晰的方法 -AllowAnonymous()

app.UseEndpoints(endpoints =>
    {
        endpoints.MapHealthChecks("/health").AllowAnonymous();
    });
Run Code Online (Sandbox Code Playgroud)

  • 可以直接使用,无需 `UseEndpoint` ilike`app.MapHealthChecks("/health-check").AllowAnonymous();` (8认同)

itm*_*nus 6

您可以在使用 AuthenticationMiddleware 之前调用 HealthCheckMiddleware:

app.Map("/health",appbuilder =>{
    appbuilder.UseMiddleware<HealthCheckMiddleware>();
});
// or 
// app.UseHealthChecks("/health");


app.UseRouting();
// make sure the authentication middleware runs after the health check middleware
app.UseAuthentication();
app.UseAuthorization();

app.UseEndpoints(endpoints =>
{
    endpoints.MapControllerRoute(
        name: "default",
        pattern: "{controller=Home}/{action=Index}/{id?}");
});
Run Code Online (Sandbox Code Playgroud)

  • 顺便说一句,我对 swagger/OpenApi 端点也有同样的问题。我需要将 `UseOpenApi` 和 `UseSwaggerUi3` 方法移到 `Configure` 中的 `UseAuthentication` 之前,这样端点就不需要身份验证来呈现 ui。 (3认同)
  • @wxt 实际上,服务的顺序并不重要,这与中间件不同:) (3认同)