1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113
|
import axios from "axios"; import {Message,MessageBox} from 'element-ui'; import store from '../store'; import {getToken} from 'utils/auth';
// 创建axios实例 const service = axios.create({ //可以不设置baseURL直接走proxy代理的地址 也可以设置全局参数 //baseURL: process.env.BASE_API, // api的base_url timeout: 50000, // 请求超时时间 }); service.interceptors.request.use( config => { if (getToken()) { // 让每个请求携带token--['access-token']为自定义key 请根据实际情况自行修改 config.headers["access-token"] = getToken(); } return config; }, error => { // do something with request error console.log(error); // for debug return Promise.reject(error); } );
// respone拦截器 处理状态码 service.interceptors.response.use( response => { /** * 下面的注释为通过response自定义code来标示请求状态,当code返回如下情况为权限有问题,登出并返回到登录页 * 如通过xmlhttprequest 状态码标识 逻辑可写在下面error中 */ const res = response.data; if (response.status === 401 || res.status === 40101) { MessageBox.confirm('你已被登出,可以取消继续留在该页面,或者重新登录', '确定登出', { confirmButtonText: '重新登录', cancelButtonText: '取消', type: 'warning' }).then(() => { store.dispatch('FedLogOut').then(() => { location.reload(); // 为了重新实例化vue-router对象 避免bug }); }) return Promise.reject('error'); } if (res.status === 40301) { Message({ message: '登录超时,请重新登录!', type: 'error', duration: 5 * 1000 }); return Promise.reject('error'); } if (res.status === 500) { Message({ message: '登录超时,请稍后重试!', type: 'error', duration: 5 * 1000 }); return Promise.reject('error'); } if (res.status === 503) { Message({ message: '登录过期,请刷新后重试!', type: 'error', duration: 5 * 1000 }); return Promise.reject('error'); } if (res.status === 504) { Message({ message: '连接服务器失败,请稍后重试!', type: 'error', duration: 5 * 1000 }); return Promise.reject('error'); } if (res.status === 40001) { Message({ message: '账户或密码错误!', type: 'warning' }); return Promise.reject('error'); } if (response.status !== 200 && res.status !== 200) { Message({ message: res.message, type: 'error', duration: 5 * 1000 }); } else { const data = response.data; try { if (data && data.data) { data.data = JSON.parse(data.data); } } catch (e) {
} return data; } }, error => { // console.log(error); // for debug Message({ message: error.message, type: 'error', duration: 5 * 1000 }); return Promise.reject(error); } ); export default service;
|