vue

axios的封装

2021-12-20  本文已影响0人  东邪_黄药师

Axios的拦截器介绍

// 创建了一个新的axios实例
const service = axios.create({
  baseURL: process.env.VUE_APP_BASE_API, // url = base url + request url
  // withCredentials: true, // send cookies when cross-domain requests
  timeout: 5000 // 超时时间
})

请求拦截器
请求拦截器主要处理 token的统一注入问题

// 请求拦截器
service.interceptors.request.use(async config => {
  // 请求接口  config是请求配置
  // 取token
  if (store.getters.token) {
    // 只要有token 就要检查token时效性
    if (CheckIsTimeOut()) {
      //  继续?
      await store.dispatch('user/lgout')
      router.push('/login') // 跳到登录
      return Promise.reject(new Error('您的token已经失效'))
    }
    // 如果存在token
    config.headers.Authorization = `Bearer ${store.getters.token}`
    // return config
  }
  // 这里一定要注意
  // 一定要return config
  return config
}, error => {
  return Promise.reject(error)
})

处理axios的响应拦截器

OK,除此之外,axios返回的数据中默认增加了一层data的包裹,我们需要在这里处理下
并且,如果执行失败,只是设置了successfalse,并没有reject,我们需要一并处理下

image.png
// 响应拦截器
service.interceptors.response.use(response => {
  // 成功执行
  // axios默认加了一层data的包裹
  const { success, message, data } = response.data
  if (success) {
    // 此时认为业务执行成功了
    return data // 返回用户所需要的数据
  } else {
    // 当业务失败的时候
    Message.error(message) // 提示消息
    return Promise.reject(new Error(message))
  }
}, async error => {
  // error 有response对象 config
  if (error.response && error.response.data && error.response.data.code === 10002) {
    // 后端告诉前端token超时了
    await store.dispatch('user/lgout') // 调用登出action
    router.push('/login') // 跳到登录页
  }
  // 失败
  // Message等同于 this.$message
  Message.error(error.message) // 提示错误
  // reject
  return Promise.reject(error) // 传入一个错误的对象  就认为promise执行链 进入了catch
})
// 检查token是否过期
function CheckIsTimeOut() {
  // 当前时间  - 存储的时间戳 > 时效性  false   tr
  return (Date.now() - getTimeStamp()) / 1000 > TimeOut
}

处理登录的返回结构问题

  async login(context, data) {
    // 经过响应拦截器的处理之后 这里的result实际上就是 token
    const result = await login(data) // 实际上就是一个promise  result就是执行的结果
    // axios默认给数据加了一层data
    // 表示登录接口调用成功 也就是意味着你的用户名和密码是正确的
    // 现在有用户token
    // actions 修改state 必须通过mutations
    context.commit('setToken', result)
  }

本节任务: 完成request环境变量和异常的处理
导出:

// 导出一个axios的实例  而且这个实例要有请求拦截器 响应拦截器
import axios from 'axios'
const service = axios.create() // 创建一个axios的实例
service.interceptors.request.use() // 请求拦截器
service.interceptors.response.use() // 响应拦截器
export default service // 导出axios实例
上一篇下一篇

猜你喜欢

热点阅读