前端无痛刷新的方案

2024-04-02 01:36

本文主要是介绍前端无痛刷新的方案,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

两种方案,第一种记录登录时间,根据后台设置的token过期时间,进行在时间内请求更换token
第二种利用axios的拦截,在返回token过期时,那么token去更换token,再用新的token去请求数据。
第二种,上代码

import axios from 'axios'
import { Message } from 'element-ui'
import store from '@/store'
import { getToken } from '@/utils/auth'var isRefreshing = false
var requests = []
// create an axios instance
const service = axios.create({baseURL: process.env.VUE_APP_BASE_API,timeout: 5000 // request timeout
})// request interceptor
service.interceptors.request.use(config => {if (store.getters.token) {config.headers['Authorization'] = 'Bearer ' + getToken()}return config},error => {console.log(error) // for debugreturn Promise.reject(error)}
)// response interceptor
service.interceptors.response.use(/*** If you want to get http information such as headers or status* Please return  response => response*//*** Determine the request status by custom code* Here is just an example* You can also judge the status by HTTP Status Code*/response => {const res = response.dataconsole.log(res, 'response.data')if (res.code === 1) {return res} else if (res.code === 50008 || res.code === 50012 || res.code === 50014) {const config = response.configif (!isRefreshing) {isRefreshing = truereturn store.dispatch('user/resetToken').then((res) => {const token = resconfig.headers['Authorization'] = tokenconfig.baseURL = '' // url已经带上了/api,避免出现/api/api的情况requests.forEach(item => item(token))requests = []// 重试当前请求并返回promise// console.log(service(config), 'service(config)')return service(config)}).catch(err => {console.log(err)// console.error('refreshtoken error =>', res)// 刷新token失败,神仙也救不了了,跳转到首页重新登录吧window.location.href = '/'}).finally(() => {isRefreshing = false})} else {return new Promise((resolve) => {// 将resolve放进队列,用一个函数形式来保存,等token刷新后直接执行requests.push((token) => {config.baseURL = ''config.headers['Authorization'] = tokenresolve(service(config))})})}} else {Message({message: res.message,type: 'error',duration: 5 * 1000})return Promise.reject(res)}},error => {return Promise.reject(error)}
)export default service

思路,
当后端返回无权限时,将请求先保存下来,return一个Promise,利用Promise去刷新token,当请求token成功,拿着心得token,拿着存的config,去再次请求,成功后reslove()
这时带来了一个问题,就是当多次请求时,会多次refresh_token
设置一个状态值,用于记录是否正在刷新token。
如果正在刷新token,将其利用Promise,将其封装为一个函数,内部自动调用resolve,存入一个数组,等到刷新token后,执行存入的函数,执行resolve(),然后依次来再次请求数据,返回正确的数据。

// 我们先看一下,定义fn1
function fn1 () {console.log('执行fn1')
}// 执行fn1,只需后面加个括号
fn1()// 回归到我们request数组中,每一项其实存的就是一个类似fn1的一个函数
const fn2 = (token) => {config.headers['X-Token'] = tokenresolve(config)
}// 我们要执行fn2,也只需在后面加个括号就可以了
fn2()// 由于requests是一个数组,所以我们想遍历执行里面的所有的项,所以用上了forEach
requests.forEach(fn => {// 执行fnfn()
})

这篇关于前端无痛刷新的方案的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/868637

相关文章

Redis客户端连接机制的实现方案

《Redis客户端连接机制的实现方案》本文主要介绍了Redis客户端连接机制的实现方案,包括事件驱动模型、非阻塞I/O处理、连接池应用及配置优化,具有一定的参考价值,感兴趣的可以了解一下... 目录1. Redis连接模型概述2. 连接建立过程详解2.1 连php接初始化流程2.2 关键配置参数3. 最大连

从入门到精通详解LangChain加载HTML内容的全攻略

《从入门到精通详解LangChain加载HTML内容的全攻略》这篇文章主要为大家详细介绍了如何用LangChain优雅地处理HTML内容,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录引言:当大语言模型遇见html一、HTML加载器为什么需要专门的HTML加载器核心加载器对比表二

RabbitMQ消息总线方式刷新配置服务全过程

《RabbitMQ消息总线方式刷新配置服务全过程》SpringCloudBus通过消息总线与MQ实现微服务配置统一刷新,结合GitWebhooks自动触发更新,避免手动重启,提升效率与可靠性,适用于配... 目录前言介绍环境准备代码示例测试验证总结前言介绍在微服务架构中,为了更方便的向微服务实例广播消息,

MySQL 迁移至 Doris 最佳实践方案(最新整理)

《MySQL迁移至Doris最佳实践方案(最新整理)》本文将深入剖析三种经过实践验证的MySQL迁移至Doris的最佳方案,涵盖全量迁移、增量同步、混合迁移以及基于CDC(ChangeData... 目录一、China编程JDBC Catalog 联邦查询方案(适合跨库实时查询)1. 方案概述2. 环境要求3.

SpringBoot3.X 整合 MinIO 存储原生方案

《SpringBoot3.X整合MinIO存储原生方案》本文详细介绍了SpringBoot3.X整合MinIO的原生方案,从环境搭建到核心功能实现,涵盖了文件上传、下载、删除等常用操作,并补充了... 目录SpringBoot3.X整合MinIO存储原生方案:从环境搭建到实战开发一、前言:为什么选择MinI

Knife4j+Axios+Redis前后端分离架构下的 API 管理与会话方案(最新推荐)

《Knife4j+Axios+Redis前后端分离架构下的API管理与会话方案(最新推荐)》本文主要介绍了Swagger与Knife4j的配置要点、前后端对接方法以及分布式Session实现原理,... 目录一、Swagger 与 Knife4j 的深度理解及配置要点Knife4j 配置关键要点1.Spri

SQLite3 在嵌入式C环境中存储音频/视频文件的最优方案

《SQLite3在嵌入式C环境中存储音频/视频文件的最优方案》本文探讨了SQLite3在嵌入式C环境中存储音视频文件的优化方案,推荐采用文件路径存储结合元数据管理,兼顾效率与资源限制,小文件可使用B... 目录SQLite3 在嵌入式C环境中存储音频/视频文件的专业方案一、存储策略选择1. 直接存储 vs

前端如何通过nginx访问本地端口

《前端如何通过nginx访问本地端口》:本文主要介绍前端如何通过nginx访问本地端口的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、nginx安装1、下载(1)下载地址(2)系统选择(3)版本选择2、安装部署(1)解压(2)配置文件修改(3)启动(4)

HTML中meta标签的常见使用案例(示例详解)

《HTML中meta标签的常见使用案例(示例详解)》HTMLmeta标签用于提供文档元数据,涵盖字符编码、SEO优化、社交媒体集成、移动设备适配、浏览器控制及安全隐私设置,优化页面显示与搜索引擎索引... 目录html中meta标签的常见使用案例一、基础功能二、搜索引擎优化(seo)三、社交媒体集成四、移动

HTML input 标签示例详解

《HTMLinput标签示例详解》input标签主要用于接收用户的输入,随type属性值的不同,变换其具体功能,本文通过实例图文并茂的形式给大家介绍HTMLinput标签,感兴趣的朋友一... 目录通用属性输入框单行文本输入框 text密码输入框 password数字输入框 number电子邮件输入编程框