Хорошо, так что я хотел бы добавить перехватчик ответа в мою глобальную конфигурацию axios, чтобы повторял запрос один раз , если он получит ошибку 401, после обновления токена.
Это моя текущая глобальная конфигурация axios:
import axios from "axios";
export default axios.create({
baseURL: process.env.REACT_APP_API,
headers: {
"content-type": "application/json"
},
responseType: "json"
});
Сейчас я провел исследование, моя проблема была решена здесь , однако я не знаю, какЯ могу прикрепить или использовать функцию перехватчика в ответе там к моему файлу конфигурации axios (после того, как я отредактирую его для моих потребностей ofc), функция перехватчика выглядит так:
createAxiosResponseInterceptor() {
const interceptor = axios.interceptors.response.use(
response => response,
error => {
// Reject promise if usual error
if (errorResponse.status !== 401) {
return Promise.reject(error);
}
/*
* When response code is 401, try to refresh the token.
* Eject the interceptor so it doesn't loop in case
* token refresh causes the 401 response
*/
axios.interceptors.response.eject(interceptor);
return axios.post('/api/refresh_token', {
'refresh_token': this._getToken('refresh_token')
}).then(response => {
saveToken();
error.response.config.headers['Authorization'] = 'Bearer ' + response.data.access_token;
return axios(error.response.config);
}).catch(error => {
destroyToken();
this.router.push('/login');
return Promise.reject(error);
}).finally(createAxiosResponseInterceptor);
}
);
}
Большое спасибо!