Я пытаюсь вернуть измененный заголовок, если срок действия маркера, отправленного пользователем, истек, чтобы я мог повторно отправить свой токен обновления, если срок его действия истек.
Я использую .NET Core 2.2 с хостингом In-Process, который имеет значение.
Вот мой ConfigureServices
метод из моего Startup.cs
.
services.AddAuthentication(options =>
{
options.DefaultAuthenticateScheme = "bearer";
options.DefaultChallengeScheme = "bearer";
}).AddJwtBearer("bearer", options =>
{
options.TokenValidationParameters = new TokenValidationParameters
{
ValidateAudience = false,
ValidateIssuer = false,
ValidateIssuerSigningKey = true,
IssuerSigningKey = new SymmetricSecurityKey(System.Text.Encoding.UTF8.GetBytes(Configuration["serverSigningPassword"])),
ValidateLifetime = true,
ClockSkew = System.TimeSpan.Zero //the default for this setting is 5 minutes
};
options.Events = new Microsoft.AspNetCore.Authentication.JwtBearer.JwtBearerEvents
{
OnAuthenticationFailed = context =>
{
if (context.Exception.GetType() == typeof(SecurityTokenExpiredException))
{
context.Response.Headers.Add("Token-Expired", "true");
}
return System.Threading.Tasks.Task.CompletedTask;
}
};
});
И затем, когда я пытаюсь получить конечную точку «авторизации» из javascript со следующим.
async function fetchWithCredentials(url, options) {
options.headers['Authorization'] = 'Bearer ' + jwtToken;
var response = await fetch(url, options);
if (response.ok) { //all is good, return the response
return response;
}
console.log(response.headers) //nothing in this array
// it will never do this "if" statement because there are no headers
if (response.status === 401 && response.headers.has('Token-Expired')) {
// refresh the token
return await fetchWithCredentials(url, options); //repeat the original request
} else { //status is not 401 and/or there's no Token-Expired header
return response;
}
}
Это изображение от наведения на заголовок. Это определенно достигает моей точки останова (для context.Response.Headers.Add()
, и я вижу счетчик = 1 (который является «Истекшим токеном», когда я его проверяю).
Наконец, вот скриншот от Почтальона после неудачного запроса, поэтому ответ отправляется, но не принимается в моем JS.
Есть идеи, почему мой заголовок не придерживается моего ответа в javascript?