"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. axios的post请求返回状态码400

    设置拦截 axios.interceptors.request.use((config) => { if (config.method === 'post') { if (!config.isF ...

  2. golang 中的struct理解

    golang实验代码 package main import("fmt") type Stu struct{ name string age int } func (stu *St ...

  3. python使用zipfile递归压缩和解压缩文件

    import shutil,zipfile,os class ToolModel(object): def dfs_get_zip_file(self,input_path, result, igno ...

  4. webpack打包原理

    什么是 webpack ? 本质上,webpack 是一个现代 JavaScript 应用程序的静态模块打包器(module bundler).当 webpack 处理应用程序时,它会递归地构建一个依 ...

  5. oracle中表加锁死锁的现象、原因及解决方案

    一.表加锁.死锁出现的现象 1.对数据库操作update.insert.delete时候,数据库无法更新,操作等待时长,操作结果不发生改变: 2.在程序中,底层(数据访问层)操作时候不成功,数据库连接 ...

  6. 求正整数2和n之间的完全数

    [题目描述] 求正整数22和nn之间的完全数(一行一个数). 完全数:因子之和等于它本身的自然数,如6=1+2+36=1+2+3 [输入] 输入n(n≤5000)n(n≤5000). [输出] 一行一 ...

  7. 【算法•日更•第四十二期】离散傅里叶变换(DFT)

    ▎前言 小编相当的菜,这篇博客难度稍高,所以有些可能不会带有证明,博客中更多的是定义. 我们将要学到的东西: 复数 暴力多项式乘法 DFT 当然,小编之前就已经写过一篇博客了,主要讲的就是基础多项式, ...

  8. asp.net core mvc和angular项目的一些问题

    最近公司布置任务,用asp.net core mvc和angular改写原来的一个用Silverlight做的项目.从来没搞过,找了两本书看了一天,又看了一天代码,大致心里有底了,就开始动手.没想到一 ...

  9. 快速排序&&归并排序

    快速排序 快速排序采用的是分治的策略,算法的具体实现过程是 1.确定一个数X(一般是选中间值X=q[l+r>>1]) 2.利用指针i,j,将数组中比X小的数放在一边,比X大的数放在另一边 ...

  10. Jmeter 常用函数(4)- 详解 __setProperty

    如果你想查看更多 Jmeter 常用函数可以在这篇文章找找哦 https://www.cnblogs.com/poloyy/p/13291704.html 前言 有看我之前写的 Jmeter 文章的童 ...