import axios from 'axios';
import { showMessage } from './statusMessage';
// 创建 axios 实例
const http = axios.create({
baseURL: process.env.VUE_APP_API_URL,
timeout: 10000,
});
// 请求重试逻辑 判断是否超时超过2次
const retryRequest = (error, retryLimit = 2) => {
const config = error.config;
// 如果 config 不存在或重试次数超过限制,则拒绝 Promise
if (!config || !retryLimit) {
return Promise.reject(error);
}
config.__retryCount = config.__retryCount || 0;
// 检查是否已经尝试过重试
if (config.__retryCount >= retryLimit) {
// 显示错误消息
showMessage(408); // 假定 408 为请求超时的状态码
return Promise.reject(error);
}
config.__retryCount += 1;
// 创建新的 Promise 来处理重试
const backoff = new Promise((resolve) => {
setTimeout(() => {
resolve();
}, 1000); // 延迟时间可以根据需要调整
});
// 在延迟后重试请求
return backoff.then(() => {
return http(config);
});
};
// 请求拦截器
http.interceptors.request.use(
config => {
const token = localStorage.getItem('token');
if (token) {
config.headers['Authorization'] = `Bearer ${token}`;
}
return config;
},
error => {
return Promise.reject(error);
}
);
// 响应拦截器
http.interceptors.response.use(
response => {
return response;
},
error => {
const { config, response } = error;
// 处理超时的情况
if (error.code === 'ECONNABORTED' && error.message.indexOf('timeout') !== -1 && !config.__isRetryRequest) {
// 调用 retryRequest 函数重试请求
return retryRequest(error, 2); // 2 表示重试限制
}
if (response) {
// 处理其他错误情况
showMessage(response.status);
}
return Promise.reject(error);
}
);
export default http;
showMessage 状态码封装
export function showMessage(status) {
let message;
switch (status) {
case 200:
message = '服务器成功返回请求的数据。';
break;
case 201:
message = '新建或修改数据成功。';
break;
case 202:
message = '一个请求已经进入后台排队(异步任务)。';
break;
case 204:
message = '删除数据成功。';
break;
case 400:
message = '发出的请求有错误,服务器没有进行新建或修改数据的操作。';
break;
case 401:
message = '用户没有权限(令牌、用户名、密码错误)。';
break;
case 403:
message = '用户得到授权,但是访问是被禁止的。';
break;
case 404:
message = '发出的请求针对的是不存在的记录,服务器没有进行操作。';
break;
case 406:
message = '请求的格式不可得。';
break;
case 410:
message = '请求的资源被永久删除,且不会再得到的。';
break;
case 422:
message = '当创建一个对象时,发生一个验证错误。';
break;
case 500:
message = '服务器发生错误,请检查服务器。';
break;
case 502:
message = '网关错误。';
break;
case 503:
message = '服务不可用,服务器暂时过载或维护。';
break;
case 504:
message = '网关超时。';
break;
default:
message = `未知错误,状态码:${status}`;
}
// 显示消息提示,可以使用 Vue 的 Toast 或 Modal 组件
console.error(message);
// 根据项目实际情况,这里可以替换为实际的弹窗或通知方式,比如使用 Element UI、Vuetify 或者其他 Vue 组件库的通知组件
}