基于vue最全的axios二次封装,包含权限判断及状态码提示请求超时后再次请求

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 组件库的通知组件
}

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容