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过期,如果用户长时间不操作,就会直接回到登录页面。
热门推荐
青岛蝴蝶楼:一座见证中国电影百年芳华的建筑
国保单位蝴蝶楼:一只展翅欲飞的建筑奇葩
珠海最新摄影打卡点大揭秘!28个绝美取景地等你来拍
春风比喻句:让你的文字更生动!
古诗词里的春风:诗意与变迁
黄鹤楼:李白的送别与崔颢的乡愁
中秋国庆必打卡!黄鹤楼最美拍照指南
黄鹤楼:李白诗中的离别文化
硫磺皂祛痘大法,你用对了吗?
银行转账怎么撤回
春节档必看!《哪吒2》国漫炸裂来袭
人民网研究院发布《2024年度服务消费热点趋势观察报告》
苏州,要有苏州的味道
失眠成了难题,如何打造一个良好的睡眠环境?
不同睡姿下枕头高度该如何选择?
学习小提琴需要掌握的练琴方法
海菲茨、米尔斯坦、梅纽因......这是你必须要了解的六位小提琴大师!
临夏八坊十三巷:探寻古韵与现代交融之美
临夏蝴蝶楼:一只展翅欲飞的建筑瑰宝
适合求婚唱的歌曲有哪些
结婚歌曲有哪些好听?如何选择婚礼上的经典曲目?
邯郸秋冬游:打卡娲皇宫、响堂山石窟和广府古城!
科技赋能古建保护,邯郸千年文化展新颜
邯郸道历史文化街区:穿越三千年古韵之旅
探访邯郸:武灵丛台与广府古城的文化之旅
诗词中的中医药:文人墨客的养生之道
生活没有诗与远方,诗词极少风花雪月,杜甫4首古诗,首首有深意
秋意浓情寄情怀——探索杜甫《秋兴八首》的诗意与人文精神
杜甫《登高》:万里悲秋常作客,百年多病独登台
Cell杂志50周年专刊:揭秘新冠病毒跨种传播的真相