axios拦截器的使用

发布于 2020-08-10  2 次阅读


axios拦截器用来在请求或响应被thencatch处理前拦截它们,也就是在发送请求之前和接收到响应之后做一些额外逻辑。例如token请求等
众所周知http请求有响应头和请求头,那么自然的,axios拦截器就可以对响应头和请求头进行一些额外的处理

请求头request

// 添加请求拦截器
axios.interceptors.request.use(function (config) {
    // 在发送请求之前做些什么
    return config;
  }, function (error) {
    // 对请求错误做些什么
    return Promise.reject(error);
});

响应头response

// 添加响应拦截器
axios.interceptors.response.use(function (response) {
    // 对响应数据做点什么
    return response;
  }, function (error) {
    // 对响应错误做点什么
    return Promise.reject(error);
  });

一般来说(在webpack中),axios拦截器写在main.js中就好了,但这样会带来一个问题,在网页刷新的时候不会走main.js。拦截器不会被触发,也就是说我们需要再写一个js文件然后被main.js引入。
例如(http.js):

import Vue from 'vue'
import axios from 'axios'
Vue.use(axios);

// 添加请求拦截器
axios.interceptors.request.use(function (config) {
    // 在发送请求之前做些什么
    return config;
  }, function (error) {
    // 对请求错误做些什么
    return Promise.reject(error);
});

// 添加响应拦截器
axios.interceptors.response.use(function (response) {
    // 对响应数据做点什么
    return response;
  }, function (error) {
    // 对响应错误做点什么
    return Promise.reject(error);
  });
export default axios;

在main.js中:

import axios from './http'

Vue.prototype.$axios = axios

这样就可以在刷新的时候也触发拦截器了