axios的封装

import axios from "axios";

import {

  serialize

} from "@/util/util";

import NProgress from "nprogress"; // progress bar

import errorCode from "@/const/errorCode";

import {

  Message,

  MessageBox

} from "element-ui";

import "nprogress/nprogress.css";

import qs from "qs";

import store from "@/store"; // progress bar style

const service = axios.create({

  headers: {

    'Content-Type': 'application/json;charset=utf-8',

    // 'Access-Control-Allow-Origin': '*',

    // 'Access-Control-Allow-Credentials':true,

    // 'Access-Control-Expose-Headers': 'content-disposition'

  },

  baseURL: process.env.NODE_ENV == "development" ? '/ywht' : process.env.VUE_APP_BASE_API,

  // withCredentials: true,

  timeout: 30 * 1000 // 请求超时时间

})

// 返回其他状态吗

service.defaults.validateStatus = function (status) {

  return status >= 200 && status <= 500; // 默认的

};

// 跨域请求,允许保存cookie

// axios.defaults.withCredentials = true;

// NProgress Configuration

NProgress.configure({

  showSpinner: false

});

// HTTPrequest拦截

service.interceptors.request.use((config) => {

    NProgress.start(); // start progress bar

    const isToken = (config.headers || {}).isToken === false;

    let token = store.getters.access_token;

    if (token && !isToken) {

      config.headers["Authorization"] = "Bearer " + token; // token

    }

    // headers中配置serialize为true开启序列化

    if (config.methods === "post" && config.headers.serialize) {

      config.data = serialize(config.data);

      delete config.data.serialize;

    }

    // 处理get 请求的数组 springmvc 可以处理

    if (config.method === "get") {

      config.paramsSerializer = function (params) {

        return qs.stringify(params, {

          arrayFormat: "repeat"

        });

      };

    }

    return config;

  },

  error => {

    return Promise.reject(error);

  }

);

// HTTPresponse拦截

service.interceptors.response.use(

  res => {

    NProgress.done();

    const status = Number(res.status) || 200;

    const message = res.data.msg || errorCode[status] || errorCode["default"];

    // 后台定义 424 针对令牌过去的特殊响应码

    // if (status === 424) {

    //   MessageBox.confirm("令牌状态已过期,请点击重新登录", "系统提示", {

    //     confirmButtonText: "重新登录",

    //     cancelButtonText: "取消",

    //     type: "warning"

    //   })

    //     .then(() => {

    //       store.dispatch("LogOut").then(() => {

    //         // 刷新登录页面,避免多次弹框

    //         window.location.reload();

    //       });

    //     })

    //     .catch(() => {});

    //   return;

    // }

    if (status !== 200 || res.data.code === 1) {

      Message({

        message: message,

        type: "error"

      });

      // return Promise.reject(new Error(message));

    } else if (res.data.code === 3) {

      Message({

        message: message,

        type: "warning"

      });

      // return Promise.reject(new Error(message));

    }

    return res;

  },

  error => {

    NProgress.done();

    Message({

      message: "连接超时,请检查网络!",

      type: "warning"

    });

    // return Promise.reject(new Error(error));

  }

);

export default service;

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值