Token续期最佳实践:双Token前后端配合方案详解
创作时间:
作者:
@小白创作中心
Token续期最佳实践:双Token前后端配合方案详解
引用
CSDN
1.
https://blog.csdn.net/m0_58600248/article/details/138916457
在现代Web应用中,Token续期是一个重要的安全机制,它确保了用户在长时间使用应用时不会因为Token过期而被迫重新登录。本文将介绍一种双Token(access token和refresh token)的前后端配合方案,详细描述了该方案的流程和具体实现步骤。
双Token,前后端配合方案
以下是我们正在采用的流程图
方案:
- 双token方案意味着有两个token, access token 和 refresh token, access token是每次请求携带的token, 为了安全和减少暴露,通常设置的时间较短,我们设置为15分钟,不同行业有不同的需求,我们对于安全性比较重视,所以设置的时间偏短。 refresh token 我们设置为一小时过期,refresh token过期后就不在续期,让用户重新登陆
- 前端需要配置做的步骤,会设置请求拦截器,如果拦截到返回结果是401并且错误信息是token过期,则会在拦截器中发送refresh token请求
- 前端会监控用户活跃时间,我们设置用户的空闲时间是10分钟,如果用户长时间没有操作,则会填提示框询问用户是否需要继续停留在该页面,该提示框会等待三分钟,如果三分钟没有任何操作或者点击了取消,则前端会进行token 的清除,让用户回到登录页面。如果点击了确定,则会发起refresh token请求,刷新所有的token。
实现步骤
- 用户点击登录,前端携带用户名密码发起请求,后端返回access token和refresh token
- 前端保存token信息到local storage
- 将access token放到请求头发起访问数据请求
- 后端校验access token是否过期,过期则返回401和token过期信息
- 前端通过请求拦截,拦截到401 和token过期信息。再拦截请求里面再次发送refresh token请求刷新,这里面可能会存在其他携带旧的token请求,这时候可以放这些失败请求放到队列中,保证只有一个请求去请求刷新就好。这时候,会将refresh token放到请求头中发起刷新token的请求。
- 后端返回全新的refresh token和access token,我们保证了refresh token过期时间一定会比access token时间长。同时,如果用户一直操作,就不存在token过期就被弹出页面的问题。
- 前端接收到新的refresh token和access token后,就可以替代浏览器本地的token,同时原来因token过期不成功的请求可以再次发送。
- refresh token过期,如果用户长时间不操作,就会直接回到登录页面。
热门推荐
吃完苹果可以喝中药吗
安卓备份数据备份怎么打开照片
小区充电桩电动车24小时可用电多少度?
Git 分支操作全解析:创建、切换、合并、删除及冲突解决
产品交付能力提升的探索与分享
司马睿不是司马家的人吗?真相到底是什么样的?
但是,先学会如何摔倒
商标注册24类究竟包含哪些具体内容?
三人游戏简单又好玩的是什么 2025耐玩的联机手游盘点
Nat Cell Biol | 脂质动员可驱动线粒体应激后的功能恢复
Nat Cell Biol | 脂质动员可驱动线粒体应激后的功能恢复
酒泉必去十大景点推荐,酒泉最值得去的10个地方,有空全部玩一遍
战神阿瑞斯的身世如何?他和雅典娜是什么关系?
H5N1禽流感在美蔓延 多国严阵以待
2025上军校需要什么条件?毕业直接是军官吗?是什么军衔?
尼古丁中毒怎么回事,怎么办
如何选择和判断合适的商铺投资项目?这类项目的风险评估如何?
《因果报应》:悬疑片的“反转”应该这么拍
屏幕镜像-AirPlay屏幕镜像无法搜索到电视,相应的解决方法
详解失信被执行人制度:如何被列入及应对措施
静脉曲张微创手术是怎么做的
如何编辑微博图文让你快速吸引关注
正确应对和科学康复,才能摆脱大腿肌肉拉伤之“痛”
【C++】质因数分解问题详解与代码实现
资源管理:构建可持续未来的关键所在
電視信號與天線:如何優化接收效果?
上海的气韵 | 一次手工活体验非遗碰撞二次元
企业收入与支出的会计处理:法律视角下的实务指南
悲剧频发,美国枪支管控政策与其他国家相比,差异在哪?
光伏逆变器详解:原理、功能与选购指南