axios的封装

Axios的拦截器介绍:

  • axios的拦截器原理如下:
    image.png

    axios拦截器
    axios作为网络请求的第三方工具, 可以进行请求和响应的拦截
    通过create创建了一个新的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)
  }
// 导出一个axios的实例  而且这个实例要有请求拦截器 响应拦截器
import axios from 'axios'
const service = axios.create() // 创建一个axios的实例
service.interceptors.request.use() // 请求拦截器
service.interceptors.response.use() // 响应拦截器
export default service // 导出axios实例
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容