request.js 1.5 KB
Newer Older
1
import axios from "axios";
2 3
import store from "@/store";
import router from "@/router";
4
import { getToken } from "@/utils/auth";
wanli's avatar
wanli committed
5 6 7

// create an axios instance
const service = axios.create({
8 9 10 11 12 13 14 15 16 17
  baseURL: process.env.BASE_URL, // api的base_url
  timeout: 15000, // request timeout
  // responseType: "json",
  // crossDomain: true,
  // xhrFields: { withCredentials: true },
  // headers: { 'X-Requested-With': 'XMLHttpRequest' },
  // headers: {
  //     "Content-Type": "application/x-www-form-urlencoded;charset=utf-8"
  // }
});
wanli's avatar
wanli committed
18 19

// request interceptor
20 21
service.interceptors.request.use(
  (config) => {
wanli's avatar
wanli committed
22
    // Do something before request is sent
23 24 25
    if (window.sessionStorage.getItem("Authorization")) {
      // 让每个请求携带token-- ['Authorization']为自定义key 请根据实际情况自行修改
      config.headers["Authorization"] = "Bearer " + getToken();
wanli's avatar
wanli committed
26
    }
27 28 29
    return config;
  },
  (error) => {
wanli's avatar
wanli committed
30 31
    // Do something with request error
    // console.log('error', error) // for debug
32 33 34
    Promise.reject(error);
  }
);
wanli's avatar
wanli committed
35 36 37

// respone interceptor
service.interceptors.response.use(
38 39
  (response) => {
    const res = response.data;
40
  
41 42
    // if (res.code === 200) return Promise.resolve(res);
    // } else return Promise.reject(res);
43 44 45 46 47
    if (res.code === 401) {
      window.sessionStorage.removeItem("Authorization")
      store.commit("frontend/login/removeToken")
      router.push({ path: "/user/login" })
    }
48 49 50 51 52 53 54 55 56

    return res;
  },
  (error) => {
    return Promise.reject(error);
  }
);

export default service;