Token无感刷新技术方案
创作时间:
作者:
@小白创作中心
Token无感刷新技术方案
引用
CSDN
1.
https://blog.csdn.net/qq_36208612/article/details/139545599
Token无感刷新技术方案是一种在用户无感知的情况下自动刷新Token,以保持用户会话连续性的技术方案。本文将详细介绍该方案的背景、理论、具体实现方案和代码示例。
背景
用户登录态过期会导致用户需要重新登录操作,体验感差,同时在表单提交页面导致用户需要重新提交表单。
理论
- 前置条件:应用需要有一个机制来定期检查Token的有效期,以及在Token接近过期时自动发起刷新请求。
- 后端支持:后端服务需要提供一个Token刷新接口,接收旧Token并验证其有效性,然后返回一个新的、有效期较长的Token。通常,JWT不支持直接刷新,需要实现基于Refresh Token的机制。Refresh Token是一种长期有效的凭据,用于获取新的Access Token。
- 前端实现:
- 定时检查与刷新:前端可以设置一个定时器,在Token即将过期时(例如,Token有效期的80%时间点),向后端发送刷新请求,用旧的Access Token或Refresh Token换取新的Access Token。
- 拦截器处理:利用HTTP请求拦截器,在每次发起请求前检查Token是否即将过期,如果快过期,则先调用刷新Token的API,然后再继续原来的请求操作。这样可以确保请求总是携带有效的Token。
- 存储管理:需要安全地存储Token和Refresh Token,前端通常使用localStorage、sessionStorage或Cookie,但要注意安全性考量,避免XSS和CSRF攻击。
- 透明化处理:确保刷新Token的操作对用户界面和体验的影响降到最低,即在后台默默完成,用户不应感受到页面刷新或跳转。
- 错误处理:如果Token刷新失败(例如,Refresh Token也已过期或被撤销),前端需要有相应的错误处理逻辑,比如引导用户重新登录。
- 优雅降级:即便刷新机制设计得很完善,也需要考虑异常情况下的用户体验,如网络问题导致刷新失败时,应提供友好的提示信息,并给予用户重新认证的途径。
通过上述策略,可以确保用户在使用应用过程中,即便Token过期也能在后台自动完成刷新,维持用户会话的连续性,达到“无感刷新”的目的。
方案
3.1. 登录态保存
单点登录之后保存token,以及refreshToken,本地持久化token以及refreshToken,以及tokenUpdateTime.
tokenUpdateTime用来判断最后一次更新token的时间。
3.2. 刷新token策略
- 设置过期时间定时刷新token,token过期时间为1小时,每一小时刷新token,刷新token之后可以同步刷新用户相关数据及需要更新的数据。
- 加载页面时,校验登录态,若是存在token以及refreshToken,检测token,发起请求是返回错误是token过期,则调用refresh Token接口,更新token以及refreshToken。更新Token refreshToken接口报错异常,则记录失败次数tryTimer,tryTimer = 1,并且1秒之后重新发起请求,重新请求发起次数最多为3次,三次尝试刷新token请求失败,则跳转到登录页或新开标签页跳转到登录页或跳出弹窗登录之后关闭弹窗,登录之后token会重新刷新,可以在原来页面继续操作。
token刷新成功之后重置tryTimer, tryTimer = 0。
3.3. 同步执行时token失效
由于同步代码执行优先级最高,定时器中的任务不一定能够及时的更新token,
3.4. 清除token
用户退出登录时清除token、refreshToken、tryTimer,移除相关的持久化数据
3.5. 流程图
实现
4.1. token管理策略
存储token相关数据在localStorage,刷新登录态及退出登录时都需及时更新数据
4.2. 刷新token策略
创建缓存请求队列 requestQueue = [ ], 是否存在有效登录token 。
请求拦截器拦截请求结果,判断是否需要刷新登录态,需要刷新登录态,推送请求进入缓存请求队列,登录态刷新成功之后,检查缓存请求队列requestQueue,依次执行缓存请求队列请求。
4.3. 刷新页面策略
监听登录态更新,根据业务需要更新页面数据。
热门推荐
中国海洋大学保研怎么样?保研率连年增加,优秀学子保送清华!
中华蜜蜂养殖方法和注意事项
粘牙糖配料
储能变流器设备的效率和能量损耗如何评估?
如何查看中考考题数据库
如何区分梅花、樱花、桃花、李花、梨花、杏花和海棠花?
这一“最幸福”的北欧国家,为何不断创造条件吸引中国汽车?
没派发完的飞机餐去哪了?
6个关键词,解读《小巷人家》里的“时代彩蛋”
猴痘到底是个什么病毒?有哪些传播途径?如何预防?
如何挑选具有潜力的超短线投资标的?这种挑选方法如何降低风险?
历史数据对比分析,优化内容投放策略
不是迷信!无论关系多好,也别收对方“5种”礼,都有科学依据的
新疆四家地市级统一法人农商银行全部开业
深圳车辆违章查询指南:8种可申诉情况及申诉流程详解
房子白菜价!这些地方,正在"鹤岗化"
区块链 百日筑基
应急科普 | 有限空间作业,务必牢记“先通风、再检测、后作业”!
纸质书与电子书:选择阅读的利与弊
怎么将pdf中的一页提取出来?提取PDF页面的几种方法
你需要的唯一煎蛋饼食谱
手工拉条子,让你品尝传统美味(掌握手艺)
最新油耗政策出炉,2026年油车是否真的要退出历史舞台
八字中财星不透干的原因与化解之道
熬夜也能亮起来!5招唤回好运气!
《金铲铲之战》S13赛季新手入门指南:从入门到精通的全方位攻略
Excel中多个相同符号的分列方法详解
悬梁刺股的典故与两位主人公
明日方舟:制造站干员配置指南
鹦鹉牡丹图的吉祥寓意与文化内涵