Axios拦截器使用旧的令牌而不是新获取的访问令牌进行重试。
创始人
2024-09-28 21:01:08
0

在Axios中,你可以通过使用拦截器来处理请求和响应。为了解决Axios拦截器使用旧的令牌而不是新获取的访问令牌进行重试的问题,你可以使用以下代码示例:

import axios from 'axios';

// 创建一个Axios实例
const api = axios.create({
  baseURL: 'https://api.example.com',
});

// 请求拦截器
api.interceptors.request.use(
  (config) => {
    // 在发送请求之前,检查是否有新的访问令牌
    const newAccessToken = getNewAccessToken();
    if (newAccessToken) {
      // 如果有新的访问令牌,将其设置到请求头中
      config.headers['Authorization'] = `Bearer ${newAccessToken}`;
    }
    return config;
  },
  (error) => {
    return Promise.reject(error);
  }
);

// 响应拦截器
api.interceptors.response.use(
  (response) => {
    return response;
  },
  (error) => {
    // 如果响应返回401错误(未授权),并且没有进行过重试
    if (error.response.status === 401 && !error.config._retry) {
      error.config._retry = true;

      // 获取新的访问令牌
      return getNewAccessToken()
        .then((newAccessToken) => {
          // 如果成功获取新的访问令牌,将其设置到请求头中并重试请求
          error.config.headers['Authorization'] = `Bearer ${newAccessToken}`;
          return axios(error.config);
        })
        .catch((error) => {
          return Promise.reject(error);
        });
    }

    return Promise.reject(error);
  }
);

// 示例API请求
api.get('/data')
  .then((response) => {
    console.log(response.data);
  })
  .catch((error) => {
    console.error(error);
  });

// 模拟获取新的访问令牌
function getNewAccessToken() {
  // 返回一个Promise,用于模拟异步操作
  return new Promise((resolve, reject) => {
    // 模拟异步获取新的访问令牌
    setTimeout(() => {
      const newAccessToken = 'new_access_token';
      resolve(newAccessToken);
    }, 2000);
  });
}

在上面的示例中,我们创建了一个名为api的Axios实例,并添加了请求和响应拦截器。在请求拦截器中,我们检查是否有新的访问令牌,并将其设置到请求头中。在响应拦截器中,如果响应返回401错误(未授权),并且没有进行过重试,我们会获取新的访问令牌,并将其设置到请求头中并重试请求。这样,即使在请求过程中访问令牌过期,我们也能够获取新的访问令牌并重试请求。

相关内容

热门资讯

aapoker怎么设置抽水!德... aapoker怎么设置抽水!德普辅助器怎么用(透视)技巧-真是曝光是有挂1、aapoker怎么设置抽...
透视解密!wepoker辅助器... 透视解密!wepoker辅助器是真的吗(透视)hhpoker有后台操控吗,教程操作(确实有挂)-哔哩...
德普之星透视软件免费入口官网!... 德普之星透视软件免费入口官网!wpk辅助插件(透视)app-一贯详细有挂德普之星透视软件免费入口官网...
透视解迷!pokemmo辅助官... 透视解迷!pokemmo辅助官网(透视)pokerworld破解版下载,教程课程(有挂透明挂)-哔哩...
wpk系统是否存在透视行为!p... wpk系统是否存在透视行为!pokermaster脚本(透视)教程-真是开挂存在有挂1、金币登录送、...
透视解迷!aapoker辅助怎... 透视解迷!aapoker辅助怎么用(透视)sohoo poker辅助,教程举措(真的有挂)-哔哩哔哩...
约局吧app有挂吗!佛手在线大... 约局吧app有挂吗!佛手在线大菠萝智能辅助器(透视)软件-确实开挂是真的挂一、佛手在线大菠萝智能辅助...
透视科普!wpk辅助是什么(透... 透视科普!wpk辅助是什么(透视)hhpoker智能辅助插件,教程办法(真实有挂)-哔哩哔哩1.hh...
wpk透视怎么安装!拱趴大菠萝... wpk透视怎么安装!拱趴大菠萝怎么开挂(透视)插件-好像解迷有挂wpk透视怎么安装!拱趴大菠萝怎么开...
透视有挂!wepoker怎么看... 透视有挂!wepoker怎么看牌型(透视)淘宝买wepoker透视有用吗,教程大纲(有挂方法)-哔哩...