工具类:Vue3--请求、响应拦截器模板

447 阅读1分钟

Vue3:请求、响应拦截器模板

路径:src/utils/request.js文件

说明:

  • baseURL:项目请求基础地址
  • timeout:响应超时时间
  • const { porfile } = store.state.user,引入store中的token数据
  • return res.data,后台返回的数据中,data为前端需要的数据
import router from '@/router'
import store from '@/store'
import axios from 'axios'

export const baseURL = 'XXXXXXX'
const request = axios.create({
  baseURL,
  timeout: 5000
})

// 请求拦截器
request.interceptors.request.use(config => {
  // 注入token
  const { porfile } = store.state.user
  if (porfile.token) {
    config.headers.Authorization = `Bearer ${porfile.token}`
  }
}, err => {
  return Promise.reject(err)
})

// 响应拦截器
request.interceptors.response.use(res => {
  return res.data
}, err => {
  // 处理token无效
  if (err.response && err.response.status === 401) {
    // 清空无效信息
    store.commit('user/setUser', {})
    // 跳转登录页面,并在路径上传递现页面的参数
    const fullPath = encodeURIComponent(router.currentRoute.value.fullPath)
    router.push('/login?redirectUrl=' + fullPath)
  }
  return Promise.reject(err)
})

// 默认导出
export default (url, method, submitData) => {
  // 封装request
  return request({
    url,
    method,
    // 判断请求类型
    [method.toLowerCase() === 'get' ? ' params' : 'data']: submitData
  })
}