问题的根本原因可能是在服务器IIS上没有正确配置身份验证机制。需要确保身份验证中间件配置正确,例如添加使用COOKIE的身份验证,并将反向代理的身份验证委托给中间件。以下是一些使用Auth0进行身份验证的示例代码,可供参考:
在Startup.cs中:
public void ConfigureServices(IServiceCollection services) { services.AddAuthentication(CookieAuthenticationDefaults.AuthenticationScheme) .AddCookie() .AddJwtBearer(JwtBearerDefaults.AuthenticationScheme, options => { options.Authority = Configuration["Auth0:Authority"]; options.Audience = Configuration["Auth0:Audience"]; }); }
public void Configure(IApplicationBuilder app, IWebHostEnvironment env) { app.UseRouting();
app.UseAuthentication();
app.UseAuthorization();
app.UseEndpoints(endpoints =>
{
endpoints.MapControllers();
endpoints.MapBlazorHub();
endpoints.MapFallbackToPage("/_Host");
});
}
在Login.razor中:
private async Task LoginUserAsync() { await HttpContext.SignInAsync( CookieAuthenticationDefaults.AuthenticationScheme, new ClaimsPrincipal(claimsIdentity)); NavigationManager.NavigateTo("/"); }
private async Task LogoutUserAsync() { await HttpContext.SignOutAsync(CookieAuthenticationDefaults.AuthenticationScheme); NavigationManager.NavigateTo("/"); }
注意:以上代码中使用的是Auth0身份验证服务,如果使用其他库,则必须相应地更改相关代码。