// src/utils/request.js
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: process.env.BASE_API, // api的base_url
timeout: 5000 // 请求超时时间
});
// request拦截器
service.interceptors.request.use(
config => {
if (store.getters.token) {
config.headers['X-Token'] = getToken(); // 让每个请求携带自定义token 请根据实际情况自定义
}
return config;
},
error => {
// Do something with request error
console.log(error); // for debug
Promise.reject(error);
}
);
// response 拦截器
service.interceptors.response.use(
response => {
const res = response.data;
// 根据返回的状态码做相应处理,例如401未授权,403禁止访问,404未找到等,可以进行页面跳转
if (res.code !== 200) {
Message({
message: res.message,
type: 'error',
duration: 5 * 1000
});
// 401:未登录 403:Token过期 404:未找到 500:服务器错误
if (res.code === 401 || res.code === 403 || res.code === 404 || res.code === 500) {
MessageBox.confirm('你已被登出,可以取消继续留在该页面,或者重新登录', '确认登出', {
confirmButtonText: '重新登录',
cancelButtonText: '取消',
type: 'warning'
}).then(() => {
store.dispatch('FedLogOut').then(() => {
location.reload(); // 为了重新实例化vue-router对象 防止bug
});
})
}
return Promise.reject('error');
} else {
return response.data;
}
},
error => {
console.log('err' + error); // for debug
Message({
message: error.message,
type: 'error',
duration: 5 * 1000
});
return Promise.reject(error);
}
);
export default service;
这段代码是对axios的封装,用于处理HTTP请求。它设置了请求超时时间,并且为请求和响应配置了拦截器。请求拦截器会在发送请求前添加token,响应拦截器则会处理服务器返回的响应,包括错误处理和页面跳转。这样的封装使得代码更加健壮和可维护。