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. 刷新页面策略
监听登录态更新,根据业务需要更新页面数据。
热门推荐
加强班级学习资源的整合计划
颈椎病会导致后脑勺疼吗
如何分析新能源股票的投资价值并做出决策?这种投资价值受到哪些因素的影响?
专家学者共话AI赋能英语教学:机遇与挑战并存
有氧运动VS无氧运动:谁才是减脂的王者?
网络工程中的AC和AP是什么?
短剧业务产业链涉及的技术系统-AI剪辑与特效
深陷中等收入陷阱泥潭:泰国,从经济奇迹到困境,曾经的发达梦为何破灭?
碳元素是如何在自然界循环的?
消费降级时代的制胜策略:解析产品价值创新
职业教育如何提升办学质量
医疗期结束后劳动能力鉴定如何操作?HR必须掌握的合规处理指南
2024年买房必懂的5个关键指标
如何保存鲜生姜?(掌握正确方法让生姜更新鲜)
MOSFET器件-亚阈值摆幅(STS)详解
大公国际:城投公司基建业务中BT和BOT模式分析
长寿花的种植与土壤配制(打造适合长寿花生长的土壤)
如何选择适合的双币信用卡助力美国留学生活
服用肠炎宁期间能否饮酒?这些饮食注意事项请收好
高考后想做近视手术,该如何选择医院、医生和手术方式?
掌握职场隐形规则,提升人际关系
智慧园区中的智能生活服务体验:未来生活的预演
理解与共处——认识自恋性人格障碍
李希贵:新时代的教师需要具备成长性思维和领导力
十句桃花古诗词,带你邂逅最美的春天
房地产开发实际流程是什么?法律合规与实务操作全解析
揭秘社交的手腕这一流行梗的深层含义与文化背景
接地气有什么作用 详解多接地气儿养生秘诀
深度解析:四大网球公开赛场地区别及其对比赛风格的影响
从成都新都到绵阳,仅需1小时