在ASP.NET Core 6 MVC应用程序中使用JwtBearer身份验证时,需要将AddJwtBearer和AddAuthentication同时添加到Startup.cs文件中的ConfigureServices方法中。但是,当我们在SignInManager中使用AddAuthentication时,出现了问题,SignInManager似乎无法识别JwtBearer令牌。
要解决这个问题,我们需要手动以编程方式将JwtBearer令牌与Identity一起使用。为此,我们需要更改ConfigureServices中的代码,以便在添加AddAuthentication之前添加Identity。然后,我们可以使用AddJwtBearer方法来将JwtBearer令牌添加到应用程序中,并使用AddIdentity方法将Identity添加到应用程序中。最后,在AddAuthentication后,我们可以添加UseAuthentication以启用认证。
以下是示例代码:
public void ConfigureServices(IServiceCollection services)
{
services.AddIdentity
services.AddJwtBearer(options =>
{
options.TokenValidationParameters = new TokenValidationParameters
{
ValidateIssuer = true,
ValidateAudience = true,
ValidateLifetime = true,
ValidateIssuerSigningKey = true,
ValidIssuer = Configuration["Jwt:Issuer"],
ValidAudience = Configuration["Jwt:Issuer"],
IssuerSigningKey = new SymmetricSecurityKey(Encoding.UTF8.GetBytes(Configuration["Jwt:Key"]))
};
});
services.AddAuthentication(options =>
{
options.DefaultScheme = JwtBearerDefaults.AuthenticationScheme;
options.DefaultAuthenticateScheme = JwtBearerDefaults.AuthenticationScheme;
options.DefaultChallengeScheme = JwtBearerDefaults.AuthenticationScheme;
})
.AddJwtBearer(options =>
{
options.TokenValidationParameters = new TokenValidationParameters
{
ValidateIssuer = true,
ValidateAudience = true,
ValidateLifetime = true,
ValidateIssuerSigningKey = true,
ValidIssuer = Configuration["Jwt:Issuer"],
ValidAudience = Configuration["Jwt:Issuer"],
IssuerSigningKey = new SymmetricSecurityKey(Encoding.UTF8.GetBytes(Configuration["Jwt:Key"]))
};
});
services.AddControllers