JWT令牌刷新机制

JWT令牌刷新机制

问题来源

JWT令牌保存在客户端,会存在过期时间,那么如果令牌一直没有变化,那么过期时间也不会发生变化。假设一个JWT令牌的过期时间是5天,但是用户在这5天内一直在使用本系统,那么理论上当到了第五天的时候就应该是自动对这个令牌进行续期操作,而不是让用户重新登录。

解决办法

双令牌机制

  1. 设置长短日期的两个令牌,两个令牌都传给客户端,客户端每次携带两个令牌请求
  2. 当两个令牌都没有过期的时候,服务端正常验证逻辑
  3. 如果短令牌过期,长令牌没有过期,那么服务端重新生成两个新的令牌返回给客户端,客户端下次就带着新的令牌请求,完成了令牌的自动刷新。

缓存令牌机制

  1. 服务端不仅将令牌返回给客户端,同时将令牌缓存到Redis中,缓存时间是客户端令牌的过期时间的一倍
  2. 如果客户端令牌过期了,但是Redis中的没有过期,那么就生成一个新的令牌返回给客户端,完成自动的令牌续期
  3. 如果两者都过期了,那么就让用户重新登录。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值