在我的.net core 2.2微服务中,我尝试从JWT令牌中提取声明以进行一些授权。身份验证是在系统的另一部分上完成的,因此我现在不需要这样做。
我在Startup.cs中使用以下代码:
services.AddAuthentication(JwtBearerDefaults.AuthenticationScheme)
.AddJwtBearer(options =>
{
var signingKey = Encoding.UTF8.GetBytes("SECRET_KEY");
options.TokenValidationParameters = new TokenValidationParameters
{
ValidateIssuer = false,
ValidateAudience = false,
IssuerSigningKey = new SymmetricSecurityKey(signingKey)
};
});
在控制器上,我有以下代码:
[Authorize]
[HttpPost]
public async Task<ActionResult<CreateResponse>> Create()
{
var userIdClaim = HttpContext.User.Claims.Where(x => x.Type == "empId").SingleOrDefault();
return Ok($"Your User ID is {userIdClaim.Value} and you can create invoices!");
}
我总是收到此错误消息和“未经授权”响应:
Microsoft.IdentityModel.Tokens.SecurityTokenInvalidSignatureException:IDX10503:签名验证失败。尝试过的键:“ [PII隐藏]”。 捕获的异常: '[PII隐藏]。 令牌:“ [PII隐藏]”。
答案 0 :(得分:0)
通过在Startup类的Configure()中添加以下内容,可以查看开发中的隐藏细节:
if (env.IsDevelopment())
{
IdentityModelEventSource.ShowPII = true;
}
收到完整的消息后,请检查所使用的密钥是否正确。