axios 拦截器、header传参和增加时间出防止缓存

axios 拦截器、header传参和增加时间出防止缓存

//axios拦截器
import axios from 'axios';
import qs from 'qs';
import iView from 'iview';
import Cookies from 'js-cookie';
import util from './util';
axios.defaults.timeout = 2000000;

// 自动根据浏览器系统语言设置语言
const navLang = navigator.language
const localLang = (navLang === 'zh-CN' || navLang === 'en-US') ? navLang : false
let lang = window.localStorage.lang || localLang || 'zh-CN';
let local = Cookies.get('local') || lang || 'zh-CN';

axios.interceptors.request.use(config => {
    config.headers['Authorization'] = Cookies.get('token'); //传入token
    config.headers['language'] = local; //传入语言参数

    //增加几口时间戳
    config.params = {
        _t: Date.parse(new Date())/1000,
        ...config.params
    }

    return config;
}, error => {
    //发送请求错误操作
    iView.Message.error('error:'+error.message);
    return Promise.reject(error);
})
axios.defaults.baseURL = util.rootPath
axios.interceptors.response.use(response => {
    //对响应数据做操作
    if(response.headers['content-type'].indexOf('application/json') > -1 ){
        if(parseInt(response.data.meta.status, 10) == 0) {
            return response
        }else if(parseInt(response.data.meta.status, 10) == 1){
            iView.Message.error(response.data.meta.message);
            return response;
        }else if(response.data.meta.status== 9) {
            iView.Message.error('登录已过期请重新登陆');
            Cookies.remove('token');
            Cookies.remove('userName');
            Cookies.remove('userId');
            window.location.href = '#/login';
        }else {
            iView.Message.error(response.data.meta.message);
            return response;
        }
    }else{
        return response
    }
    
    
    
}, error => {
    iView.Message.error('error:'+error.message);
    return Promise.reject(error);
})

export default axios;
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值