vue之axios token 响应拦截请求

vue之axios token 响应拦截请求

import axios from 'axios';
import router from './router'
import { Message } from 'element-ui';

//vue中引用NProgress加载进度条
import NProgress from 'nprogress'
import 'nprogress/nprogress.css'

// axios 配置
axios.defaults.timeout = 50000 //设置接口响应时间
axios.defaults.baseURL = 'http://localhost:3000/api/v1'

// 请求在到达服务器之前,先会调用use中的这个回调函数来添加请求头信息
axios.interceptors.request.use(config => {
  NProgress.start()
  // 为请求头对象,添加token验证的token字段
  config.headers.token = window.localStorage.getItem('token')
  // 在最后必须 return config
  return config
})

// response 拦截器中,  隐藏进度条NProgress.done()
axios.interceptors.response.use(config => {
  NProgress.done()
  //获取错误状态码
  const { status } =config.data;
  if(status==401){
    Message.error('token失效,请重新登录!');
    window.localStorage.clear();
    router.push('/login');
  }
  return config
})

export default axios

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
©️2022 CSDN 皮肤主题:1024 设计师:我叫白小胖 返回首页
评论

打赏作者

前端大冤种

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值