import axios from "axios"; import store from "@/store"; import router from "@/router"; import { getToken } from "@/utils/auth"; // create an axios instance const service = axios.create({ 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" // } }); // request interceptor service.interceptors.request.use( (config) => { // Do something before request is sent if (window.sessionStorage.getItem("Authorization")) { // 让每个请求携带token-- ['Authorization']为自定义key 请根据实际情况自行修改 config.headers["Authorization"] = "Bearer " + getToken(); } return config; }, (error) => { // Do something with request error // console.log('error', error) // for debug Promise.reject(error); } ); // respone interceptor service.interceptors.response.use( (response) => { const res = response.data; // if (res.code === 200) return Promise.resolve(res); // } else return Promise.reject(res); if (res.code === 401) { window.sessionStorage.removeItem("Authorization") store.commit("frontend/login/removeToken") router.push({ path: "/user/login" }) } return res; }, (error) => { return Promise.reject(error); } ); export default service;