响应拦截和请求拦截

261 阅读1分钟
import axios from 'axios'
import store from '@/store'
import router from '@/router'

// baseURL设置/超时时间设置
const instance = axios.create({
 
  baseURL: '根路径',
  timeout: 5000 //超时时间
})

// 添加请求拦截器
instance.interceptors.request.use(
  function (config) {
    // 1. 获取token
    const { token } = store.state.user.profile
    // 2. 请求头设置token
    if (token) {
      config.headers.Authorization = `Bearer ${token}`
    }
    return config
  },
  function (error) {
    // 对请求错误做些什么
    return Promise.reject(error)
  }
)

// 添加响应拦截器
instance.interceptors.response.use(
  function (response) {
    return response.data
  },
  function (error) {
    // 对响应错误做点什么
    if (error.response && error.response.status === 401) {
      const redirectUrl = encodeURIComponent(router.currentRoute.value.fullPath)
      router.push('/login?redirectUrl=' + redirectUrl)
    }
    return Promise.reject(error)
  }
)

/**
 * @param {String} - url  请求地址
 * @param {String} - method  请求类型
 * @param {Object} - submitData  对象类型,提交数据
 */
const request = (url, method, submitData) => {
  return instance({
    url,
    method,
    [method.toLowerCase() === 'get' ? 'params' : 'data']: submitData
  })
}

export default request