import axios from 'axios' import { message, Modal } from "ant-design-vue"; import qs from 'qs'; // create an axios instance const service = axios.create({ // baseURL: process.env.BASE_API, // api的base_url timeout: 5000, // 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 (getCookies(_CONST.TOKEN)) { // config.headers['Authorization'] = 'Bearer ' + getCookies(_CONST.TOKEN) // 让每个请求携带token-- ['Authorization']为自定义key 请根据实际情况自行修改 // } // 在发送请求之前做某件事 if ( config.method === "post" || config.method === "put" || config.method === "delete" ) { // 序列化 config.data = qs.stringify(config.data); } // console.log('config', config); return config }, error => { // Do something with request error // console.log('error', error) // for debug Promise.reject(error) }) // respone interceptor service.interceptors.response.use( response => { // message.success('数据通讯完成', 1); const { data } = response; if (data) { return data } return Promise.reject(response); }, error => { /** * 下面的注释为通过response自定义code来标示请求状态,当code返回如下情况为权限有问题,登出并返回到登录页 * 如通过xmlhttprequest 状态码标识 逻辑可写在下面error中 */ // console.log('error', error) const res = error.response; // console.log(res); if (res && res.data) { const { code, error, error_description } = res.data; // console.info(code) // console.info(error) // console.info(error_description) // 100401:非法的token; 100412:其他客户端登录了; 100413:Token 过期了; if (code === 100401 || code === 100412 || code === 100413) { // MessageBox.confirm('操作失败,原因:' + error + ',可以取消继续留在该页面,或者重新登录', '操作提示', { // confirmButtonText: '重新登录', // cancelButtonText: '取消', // type: 'warning' // }).then(() => { // removeCookies(_CONST.TOKEN); // location.reload();// 为了重新实例化vue-router对象 避免bug // }) } else { let error; if (!error) { error = "请求失败,异常: " + res.statusText + ' [' + res.status + ']'; } message.error(error, 5); } } else { message.error("请求失败," + error, 5); } return Promise.reject(error) }) export default service