【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)
    }
)
相关推荐
许彰午几秒前
我手写了一个 Java 内存数据库(二):B+ 树的插入与分裂
java·开发语言·面试
zhouwy1132 分钟前
Java 快速入门笔记:从基础语法到 Spring Boot 实战
java
jinanwuhuaguo3 分钟前
(第二十九篇)OpenClaw 实时与具身的跃迁——从异步孤岛到数字世界的“原住民”
前端·网络·人工智能·重构·openclaw
广州华水科技9 分钟前
深度测评2026年单北斗GNSS位移监测系统推荐,与高口碑变形监测设备一同引领行业新风尚
前端
极创信息25 分钟前
信创产品认证怎么做?信创产品测试认证的主要流程
java·大数据·数据库·金融·软件工程
SamDeepThinking44 分钟前
并发量就算只有2,该上锁还得上呀
java·后端·架构
Alice-YUE1 小时前
【js高频八股】防抖与节流
开发语言·前端·javascript·笔记·学习·ecmascript
Sam_Deep_Thinking1 小时前
如何让订单系统和营销系统解耦
java·架构·系统架构
lzhdim1 小时前
SQL 入门 12:SQL 视图:创建、修改与可更新视图
java·大数据·服务器·数据库·sql
是上好佳佳佳呀2 小时前
【前端(十一)】JavaScript 语法基础笔记(多语言对比)
前端·javascript·笔记