问题的根本原因可能是在服务器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身份验证服务,如果使用其他库,则必须相应地更改相关代码。