Token刷新策略

刷新Token的方法

安全性较低

前端判断过期时间

  1. 每次请求时,判断token是否临期。
  2. 如果临期,则调用后端请求刷新token接口。
  3. 后端返回新token后,用新token替换旧token。
  4. 继续请求原始接口。

此方案缺点:

  1. 前后端时间可能存在偏差
  2. 前端的时间可能被篡改
  3. token直接存在前端,会被浏览器插件和脚本获取
  4. token传输过程中被绑架,然后直接调用后台数据

后端判断过期时间

  1. 前端每次请求时都会带着token请求
  2. 后端在收到请求后,判断token是否过期。
  3. 如果过期,则返回401状态码。
  4. 前端接收到401状态码后,调用后端请求刷新token接口。
  5. 后端返回新token后,用新token替换旧token。
  6. 继续请求原始接口。

缺点:

  1. 只有一个token,一泄露就会被人用来访问资源
  2. 多个并发请求可能导致token刷新冲突,例如,两个接口都401,然后会刷新两个token,然后token就会覆盖了。

安全性高

双token机制

  1. 后台生成两个token,一个access_token,一个refresh_token。前者用来访问资源,后者用来刷新access_token。
  2. 前端每次请求,携带access_token。
  3. 后端在收到请求后,判断access_token是否过期。
  4. 如果过期,则判断refresh_token是否过期。
  5. 如果refresh_token也过期,则返回401状态码。
  6. 如果refresh_token未过期,则调用刷新token接口,返回新的access_token。
  7. 前端接收到新token后,用新token替换旧token。
  8. 继续请求原始接口。
  9. Refresh Token是滑动过期策略,即只要用这个Refresh Token访问刷新接口,就会使这个Refresh Token的过期时间延长。如果一段时间内,用户没有使用这个,那么refresh_token也会过期。
    缺点:
  10. refresh_token需要保存在服务器,且不能被恶意用户访问。
相关推荐
不愿是过客1 天前
java实战干货——长方法深递归
java
小北方城市网1 天前
Redis 分布式锁高可用实现:从原理到生产级落地
java·前端·javascript·spring boot·redis·分布式·wpf
六义义1 天前
java基础十二
java·数据结构·算法
毕设源码-钟学长1 天前
【开题答辩全过程】以 基于SpringBoot的智能书城推荐系统的设计与实现为例,包含答辩的问题和答案
java·spring boot·后端
笨手笨脚の1 天前
深入理解 Java 虚拟机-03 垃圾收集
java·jvm·垃圾回收·标记清除·标记复制·标记整理
莫问前路漫漫1 天前
WinMerge v2.16.41 中文绿色版深度解析:文件对比与合并的全能工具
java·开发语言·python·jdk·ai编程
九皇叔叔1 天前
【03】SpringBoot3 MybatisPlus BaseMapper 源码分析
java·开发语言·mybatis·mybatis plus
挖矿大亨1 天前
c++中的函数模版
java·c++·算法
a程序小傲1 天前
得物Java面试被问:RocketMQ的消息轨迹追踪实现
java·linux·spring·面试·职场和发展·rocketmq·java-rocketmq
青春男大1 天前
Redis和RedisTemplate快速上手
java·数据库·redis·后端·spring·缓存