当前位置:   article > 正文

vue之axios token 响应拦截请求_vue3拦截器中配置token

vue3拦截器中配置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
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Gausst松鼠会/article/detail/715672
推荐阅读