"use strict";
import QS from "qs";
import Axios from "axios";
import store from "@/store/index";
import { MessageBox } from "element-ui";
// http request 拦截器
Axios.interceptors.request.use(
  config => {
    // console.log('当前环境变量',process.env.VUE_APP_ENV)
    // console.log('当前环境地址',process.env.VUE_APP_URL)
    config.baseURL = process.env.VUE_APP_URL;
    if (!config["params"]) {
      config["params"] = {};
    }
    config.params["token"] = store.state.user.token;
    config.headers["AUTHORIZATION"] = store.state.user.token;
    return config;
  },
  err => {
    return Promise.reject(err);
  }
);
// 添加响应拦截器
Axios.interceptors.response.use(
  res => {
    // 对响应数据做点什么
    console.log('响应',res)
    switch (res.data.code) {
      case 200:
        return res.data;
      case 402:
        MessageBox.confirm(
          `${res.data.msg},可以取消继续留在该页面,或者重新登录`,
          "确定登出",
          {
            confirmButtonText: "重新登录",
            cancelButtonText: "取消",
            type: "warning"
          }
        ).then(() => {
          location.reload(); // 为了重新实例化vue-router对象 避免bug
        });
        break;
      case undefined:
        return res;
      default:
        return res.data;
    }
  },
  error => {
    console.log('aaaa')
    // 如果需要通过服务端返回的数据在组件内进行判定,
    // 由于拦截器是reject的错误,并不能在组件中读取err信息,可以改reject为 resolve 并且返回err.response
    // 对响应错误做点什么
    let code = error.response.status; // 获取错误状态码
    let msg = error.response.data.msg; // 获取提示信息
    switch (code) {
      case 401:
        MessageBox.confirm(
          `${msg},可以取消继续留在该页面,或者重新登录`,
          "确定登出",
          {
            confirmButtonText: "重新登录",
            cancelButtonText: "取消",
            type: "warning"
          }
        ).then(() => {
          location.reload(); // 为了重新实例化vue-router对象 避免bug
        });
        break;
      case undefined:
        return Promise.reject(error);
      default:
        return Promise.reject(error);
    }
  }
);
export default {
  get: option => {
    var options = {
      url: option.url,
      timeout: 10000,
      method: option.method || "get",
      params: option.data || {},
      success: option.succ || function() {},
      error: option.error || function() {}
    };
    return Axios.request(options);
  },
  post: option => {
    var options = {
      url: option.url,
      timeout: 1000000,
      headers: {
        "Content-Type": "application/x-www-form-urlencoded; charset=utf-8"
      },
      method: option.method || "post",
      data: option.data,
      success: option.succ || function() {},
      error: option.error || function() {}
    };
    if (option.data && option.typea == 1) {
      options.headers["content-Type"] = "application/json;charset=utf-8";
      options.beforeSend = function(xhr) {
        xhr.setRequestHeader("Test", "testheadervalue");
      };
    } else if (option.data && option.typeb == "excel") {
      options.responseType = "blob";
      options.data = QS.stringify(options.data);
    } else if (option.data && option.typea == 2) {
      options.headers["content-Type"] = "multipart/form-data";
    } else {
      options.data = QS.stringify(options.data);
    }
    return Axios.request(options);
  },
  delete: option => {
    var options = {
      url: option.url,
      timeout: 10000,
      method: option.method || "delete",
      params: option.data || {},
      success: option.succ || function() {},
      error: option.error || function() {}
    };
    return Axios.request(options);
  },
  put: option => {
    var options = {
      url: option.url,
      timeout: 10000,
      headers: {
        "Content-Type": "application/x-www-form-urlencoded; charset=utf-8"
      },
      method: option.method || "PUT",
      params: option.data || {},
      success: option.succ || function() {},
      error: option.error || function() {}
    };
    if (option.data && option.typea == 1) {
      options.headers["content-Type"] = "application/json;charset=utf-8";
      options.data = QS.stringify(options.data);
    }
    return Axios.request(options);
  }
};

vue-axios拦截器的更多相关文章

  1. vue axios拦截器 + 自编写插件 实现全局 loading 效果;

    项目需求:用自定义的 .gif 图标实现全局 loading 效果:为避免在每个页面手动添加,且简单高效的实现,经查阅资料,最终采用了 vue axios拦截器 + 自编写 loading 插件:下面 ...

  2. vue --- axios拦截器+form格式请求体

    在vue2.x中使用CLI生成的模板有很大改变,需要自己手动在main.ts同级目录下新建interceptors.ts interceptors.ts import axios from 'axio ...

  3. vue axios 拦截器

    前言 项目中需要验证登录用户身份是否过期,是否有权限进行操作,所以需要根据后台返回不同的状态码进行判断. 第一次使用拦截器,文章中如有不对的地方还请各位大佬帮忙指正谢谢. 正文 axios的拦截器分为 ...

  4. vue axios拦截器的封装

    // request.js import axios from 'axios' import qs from 'qs' // 创建axios实例 const service = axios.creat ...

  5. vue axios拦截器介绍

    关于axios的拦截器是一个作用非常大,非常好用的东西.分为请求拦截器和响应拦截器两种.我一般把拦截器写在main.js里. 1. 请求拦截器 请求拦截器的作用是在请求发送前进行一些操作,例如在每个请 ...

  6. vue axios拦截器加全局loading

    import axios from 'axios' import util from './util' import {showFullScreenLoading, tryHideFullScreen ...

  7. Vue基于vuex、axios拦截器实现loading效果及axios的安装配置

    准备 利用vue-cli脚手架创建项目 进入项目安装vuex.axios(npm install vuex,npm install axios) axios配置 项目中安装axios模块(npm in ...

  8. vue导航守卫和axios拦截器的区别

    在Vue项目中,有两种用户登录状态判断并处理的情况,分别为:导航守卫和axios拦截器. 一.什么是导航守卫? vue-router 提供的导航守卫主要用来通过跳转或取消的方式守卫导航.(在路由跳转时 ...

  9. Vue2学习小记-给Vue2路由导航钩子和axios拦截器做个封装

    1.写在前面 最近在学习Vue2,遇到有些页面请求数据需要用户登录权限.服务器响应不符预期的问题,但是总不能每个页面都做单独处理吧,于是想到axios提供了拦截器这个好东西,再于是就出现了本文. 2. ...

  10. axios拦截器搭配token使用

    在了解到cookie.session.token的作用后学习token的使用 cookie是随着url将参数发送到后台,安全性最低,并且大小受限,不超过4kb左右,它的数据保存在客户端 session ...

随机推荐

  1. C#设计模式之16-迭代器模式

    迭代器模式(Iterator Pattern) 该文章的最新版本已迁移至个人博客[比特飞],单击链接 https://www.byteflying.com/archives/417 访问. 迭代器模式 ...

  2. Aspnet Zero中使用Windows service (Topshelf)来承载Quartz.net任务

    Aspnet Zero使用Windows service (Topshelf)来承载Quartz.net任务 网上有很多关于如何使用Topshelf创建ABP的Quartz windows服务,但很少 ...

  3. 利用Express+MySQL进行简单的增删改查

    前言: 随着JavaScript语言的快速发展,其功能越来越强大,能做的事情也越来越多. 目前,web前端工程师能够利用NodeJS搭建服务,也成为了越来越多互联网公司对前端开发的硬性要求. 本文主要 ...

  4. 2-1关闭和重启linux系统

    0x01 shutdown命令 语法:shutdown [选项][时间][警告信息] 选项 含义 -k 并不执行shutdown,只是发出警告信息 -r 重新启动系统 -h 关闭系统 -c 取消运行s ...

  5. 使用CrashHandler获取应用crash信息

      Android应用不可避免会发生crash,也称之为崩溃.发生原因可能是由于Android系统底层的bug,也可能是由于不充分的机型适配或者是糟糕的网络情况.当crash发生时,系统会kill掉正 ...

  6. 解决QT5移植报错:This application failed to start because no Qt platform plugin could be initialized

    今天自己基于Pyqt5开发了一个软件,打包成exe后在自己的电脑上运行正常,在其他机器上提示: This application failed to start because no Qt platf ...

  7. 尾递归(java)

    一般递归: 一个过程或函数在其定义或说明中有直接或间接调用自身的一种方法,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多 ...

  8. Javascript模块化编程(二):AMD规范 (转)

    原文作者: 阮一峰 日期: 2012年10月30日 这个系列的第一部分介绍了Javascript模块的基本写法,今天介绍如何规范地使用模块. (接上文) 七.模块的规范 先想一想,为什么模块很重要? ...

  9. python基础 Day6

    python Day6 id 可以获得python的内存地址 id的举例子 a=100 print(id(a)) #140712544153072 这里就是该对象的内存地址 is 判断的是比较内存地址 ...

  10. linux,运维,部署 相关

    基础 linux基础命令 linux基础 部署 docker