【axios取消请求】如何在token过期后取消未响应的请求

功能背景:

我们在实际项目中通常会遇到登录过期后会跳登录页的情况,回跳过程会根据接口请求的状态码判断是否登陆状态过期,并给出用户提示,如果此时存在多个请求接口同时调用,就会同时报出多个登录过期的提示,如何避免多个提示同时报出的情况呢?那我们就需要用到取消接口请求的功能

方法:

我们基于axios提供的AbortController对象(fetch提供的原生API)来实现这一功能

步骤:

1.创建接口请求映射表
javascript 复制代码
let abortControllers = new Map()
2.在请求拦截器中存储键值对
javascript 复制代码
Axios.interceptors.request.use(
    (config) => {
        const controller = new AbortController()
        const signal = controller.signal
        const requestKey = `${config.url}`
        // 请求地址与控制器绑定
        abortControllers.set(requestKey, controller)
        config.metadata = { signal, requestKey } // 自定义字段用于存储
        return config
    },
    (error) => {
        return Promise.reject(error.data.error.message)
    }
)
3.响应拦截其中判断是否过期
javascript 复制代码
Axios.interceptors.response.use(
    (res) => {
        if (res.status === 200) {
            if (res.data.code == '10008') {
                ElMessage.warning('登录已过期,请重新登录!')
                // 取消所有还未执行的接口请求
                abortControllers.forEach((controller) => controller.abort())
                abortControllers.clear() // 清空控制器映射
                router.push('/login')
                return
            } else {
                // 完成的接口在映射表中删除
                const requestKey = `${res.config.url}`
                abortControllers.delete(requestKey)
                return res.data
            }
        }
    },
    (error) => {
        // 出错的接口在映射表中删除
        const requestKey = `${error.config.url}`
        abortControllers.delete(requestKey)
        return Promise.reject(error.response.status)
    }
)
相关推荐
hey_ner1 分钟前
页面PDF文件格式预览(不使用pdf.js)
前端·javascript
luckyPian2 分钟前
前端+AI:HTML5语义标签(一)
前端·ai·面试·html·html5·ai编程
普通码农3 分钟前
Vue3 + dom-to-image 实现高质量截图复制与下载功能
前端
王六岁9 分钟前
🐍 前端开发 0 基础学 Python 入门指南:数字与字符串篇
前端·python·全栈
okjohn10 分钟前
浅谈需求分析与管理
java·架构·系统架构·软件工程·产品经理·需求分析·规格说明书
over69723 分钟前
JavaScript恋爱物语:当代码学会送花,对象字面量也能当红娘!
javascript
用户03321266636724 分钟前
Java添加、设置和删除PDF图层:
java
tiantian_cool28 分钟前
HarmonyOS 开发环境配置指南 - macOS 版
前端
荣光波比31 分钟前
K8S(十)—— Kubernetes核心组件详解:Pod控制器与配置资源管理
java·容器·kubernetes
m0_6515939139 分钟前
企业级订单系统架构设计:领域驱动 vs 数据驱动实践指南
java·系统架构·领域驱动ddd