封装 axios

Axios 是一个基于 promise 的 HTTP 库,可以用在浏览器和 node.js 中。

import Vue from 'vue';

import VueCookie from 'vue-cookie';
import axios from 'axios';
// import toastr from '../assets/toastr.min';
// Vue.use(axios)




let http = {};
// let _baseURL = '/vpaas'
let _baseURL = 'http://localhost:8080/vpaas'
let ContentType = "application/json";
http.baseURL = _baseURL;


/**
 * 定制post方法
 * @param  {String} url  请求地址
 * @param  {Object} data 请求参数
 * @return {json}
 */
http.post = function (url, data) {
  let config = {
    //请求的接口,在请求的时候,如axios.get(url,config);这里的url会覆盖掉config中的url
    url: url,
    //请求方法同上
    method: 'post', // default
    //基础url前缀
    baseURL: _baseURL,
    transformResponse: [function (data1) {
      var data = data1;
      if (typeof data1 == "string") {
        data = JSON.parse(data1);
      }
      //这里提前处理返回的数据;
      if (data.message && (data.data === 'login.invalid.token')) {
        alert("超时请重新登陆");
          // sessionStorage.setItem("access-user",null);
          window.localStorage.removeItem("access-user");
          window.location.href = '/';
      }
      return data;
    }],
    //请求头信息
    headers: {'access-user': window.localStorage.getItem('access-user'), 'Content-Type': ContentType},
    data: data,
    //设置超时时间
    //timeout: 5000,
    withCredentials: true,
    //返回数据类型
    responseType: 'json', //default
  };
  return axios.post(url, data, config);
};


/**
 * 定制get方法
 * @param  {String} url 请求地址
 * @return {json}
 */
http.get = function (url) {
  let config = {
    //请求的接口,在请求的时候,如axios.get(url,config);这里的url会覆盖掉config中的url
    url: url,
    //请求方法同上
    method: 'get', // default
    //基础url前缀
    baseURL: _baseURL,
    transformResponse: [function (data1) {
      //这里提前处理返回的数据;
      var data = data1;
      if (typeof data1 == "string") {
        data = JSON.parse(data1);
      }
      if (data.message && (data.data === 'login.invalid.token')) {
        alert("超时请重新登陆");
          // sessionStorage.setItem("access-user",null);
          window.localStorage.removeItem("access-user");
          window.location.href = '/';
      }
      return data;
    }],


    //请求头信息
    // headers: {'Authorization': VueCookie.get('token')},
    headers: {'access-user': window.localStorage.getItem('access-user'), 'Content-Type': ContentType},
    withCredentials: true,
    //返回数据类型
    responseType: 'json', //default
  };
  return axios.get(url, config);
};


// 这个函数是做什么的?
http.checkAuth = function () {
  let token = VueCookie.get('token');
  if (token != undefined && token != 'undefined' && token) {
    console.log("cookie中存有token: " + token);
    this.authenticated = true;
  } else {
    console.log("cookie中没有token");
    alert("请登陆系统");
    this.authenticated = false;
  }
};


/**
 * 定制delete方法
 * @param  {String} url 请求地址
 * @return {json}
 */
http.delete = function (url) {
  let config = {
    //请求的接口,在请求的时候,如axios.get(url,config);这里的url会覆盖掉config中的url
    url: url,
    //请求方法同上
    method: 'delete', // default
    //基础url前缀
    baseURL: _baseURL,
    transformResponse: [function (data1) {
      var data = data1;
      if (typeof data1 == "string") {
        data = JSON.parse(data1);
      }
      //这里提前处理返回的数据;
      if (data.message && (data.data === 'login.invalid.token')) {
        alert("超时请重新登陆");
          // sessionStorage.setItem("access-user",null);
          window.localStorage.removeItem("access-user");
          window.location.href = '/';
        // }.bind(this), 3000);
      }
      return data;
    }],


    //请求头信息
    // headers: {'Authorization': VueCookie.delete('token')},
    headers: {'access-user': window.localStorage.getItem('access-user'), 'Content-Type': ContentType},
    withCredentials: true,
    //返回数据类型
    responseType: 'json', //default
  };
  return axios.delete(url, config);
};


export default http;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值