token自动刷新(java)

博客探讨了在使用JWT进行身份验证时,如何避免用户在一小时有效期后突然被踢出系统的不佳体验。提出两种解决方案:一是后端通过拦截器在每次请求时刷新Token;二是采用refresh_token机制,前端检测并自动请求更新access_token。这两种方法旨在确保用户在持续操作时保持登录状态。
摘要由CSDN通过智能技术生成
问题

token设置过期时间后,如果不做其他处理,那么会存在一点小问题,比如把token设置有效期为一小时,有个用户登录系统后一直在操作,当到一小时后,突然该用户就被报401,这个体验是非常不好的。

解决方法
  1. 后端解决
    思路:后端拦截器中拦截每个请求,每次请求过来,都调用redis重新设置过期,当然redis的key要设计好,每次刷新的都是当前登录用户的key,这样如果你一直操作,则你的过期时间一直在刷新,这个方法比较简单直接。
    参考:后端刷新token
  2. 使用refresh_token
    此方法需要前端来实现,后端需要在用户登陆成功后除了返回access_token外还要返回refresh_token,另外还要多提供一个刷新token的接口,前端去判断何时调用该接口。
    参考:refresh_token来自动刷新token
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值