axios 无感刷新token

本文介绍了如何在前端响应拦截器中实现token的有效管理,当请求失败时检查token状态,如果过期则获取新token并重试请求,确保API调用的正常进行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

写在响应拦截里

// respone拦截器
service.interceptors.response.use(
  async response => {
    Toast.clear()
    const res = response.data
    if (!res.isSuccess) {
      // 获取token 并存储到本地存储里
      let token = await store.dispatch('GETTOKEN')
      let config = response.config
      // 这里需要使用最新的token 否则携带的是过期token
      config.headers['token'] = token
      // 重新执行token过期的请求
      const resp = await service.request(response.config)
      return Promise.resolve(resp)
    }

    return Promise.resolve(res)
  },
  error => {
    Toast.clear()
    console.log('err' + error) // for debug
    return Promise.reject(error)
  }
)

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值