美文网首页vue
axios的封装

axios的封装

作者: 东邪_黄药师 | 来源:发表于2021-12-20 10:13 被阅读0次

    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)
      }
    

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

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

    相关文章

      网友评论

        本文标题:axios的封装

        本文链接:https://www.haomeiwen.com/subject/idpgfrtx.html