实现多端登录的相关思路

本文探讨了如何利用Redis实现多端登录状态管理,包括登录态维持、动态延长登录态、区分不同设备、获取其他设备状态以及实现同端互斥。方案包括使用token存储在Redis中,通过刷新令牌或在请求时更新token的有效期,以及通过用户ID和设备信息区分设备,实现设备状态管理和强制下线功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

登录态怎么维持

登录有很多种实现方案,也有各种成熟的方案比如依靠ssesioncookie等等

这里主要是使用有状态token去模拟实现共享ssesion

思路

生成token表示当前用户,将token存储在redis中,使用token的过期去控制用户登录态的过期

登录态即将过期,用户来请求了,需要动态的延长

思路

方案一

可以选择模仿OAuth2,在一开始认证成功时,返回两个token,一个作为常规请求的token,一个作为更新令牌(refresh token),用于获取新的令牌。令牌到期前,用户使用 refresh token 发一个请求,去更新令牌。

方案二

在用户正常的请求进入服务端的时候,对token进行有效期校验,针对即将过期的token直接更新其到期时间。实现方便,后续就用这个方案讲

怎么区分多个设备

思路

首先把问题先简化一下,如果已经有登录了,二次调用登录接口时,怎么知道当前账号已经登录过了

很容易想到,在redis中存储如下键值对(redis中的key都会携带前缀表示相关业务,这里主要展示思想,所以省略前缀,后同)

key:token , value:userid
key:u
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值