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

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,064评论 5 466
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,606评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,011评论 0 328
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,550评论 1 269
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,465评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 47,919评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,428评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,075评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,208评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,185评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,191评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,914评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,482评论 3 302
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,585评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,825评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,194评论 2 344
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,703评论 2 339

推荐阅读更多精彩内容