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过期,如果用户长时间不操作,就会直接回到登录页面。
热门推荐
老年人新发黑色素痣,当心是黑色素瘤!
海航控股豪购40架ARJ21-700,国产飞机起飞!
清明节祭扫,这些防火小贴士你知道吗?
《远方的山楂树》配角演员的演技大赏
职场人更换手机号指南:从选号到信息更新全攻略
上官皇后的“穷绔”穿搭:从宫廷革新到服饰革命
丹参川芎葛根:6克6克10克配比调理身体
很多人喜欢吃红薯叶老是做不好,掌握好方法,你也可以
六峰山:广西钦州的自然人文双绝胜景
利福平让你的尿液变红了吗?
云南非物质文化遗产美食——弥勒卤鸡
合肥岱山湖:8000亩湖景、元代古刹与水上乐园的奇妙组合
插队砸车被罚,法律教你正确应对
经常梦到逝去的亲人是什么原因?
房屋买卖定金首付指南:支付要点与法律效力全解析
高血压患者饮酒真的那么可怕吗?
九成人群曾染发,当心这些有害成分,专家建议改用天然染发
新型饲料添加剂HMF研发成功:高效绿色生产,安全无毒,节粮降本效果显著
“刀不借”的智慧:避免家庭纠纷的千年古训
居家健身热潮:掌握基础动作,雕刻完美肌肉线条
油价迎年内第九降:92号汽油每升降0.14元,车主月省20元
钻戒尺寸小改大的办法和注意事项
从散步到游泳:冠心病患者的科学运动康复方案
从《抱朴子》到现代游戏:白泽形象的演变与传承
婴儿奶粉喂养指南:适量才是关键,过量不足都有害
驾照新规来袭,驾考流程大变革!
纳税信用A级可享八大激励,含税务便利、融资优惠等
权谋智慧:曹操的职场成功之道
清甜遇上鲜嫩,雪莲果蒸鸡翅成冬日养生新宠
三奇堂养生健肝茶,脂肪肝的救星?