使用redis实现登录token的需求

本文探讨了在用户登录成功后如何利用Redis存储和管理Token,以减轻关系型数据库的压力。通过创建随机令牌并存储在Redis的哈希中,实现了用户信息与令牌的映射。伪代码展示了添加、更新和清理令牌的流程,建议定期清理以维持服务性能,例如每秒清除超限的100个令牌。
摘要由CSDN通过智能技术生成

使用redis实现登录token的需求

需求分析:
我们用户登录成功后,
需要记录用户的基本信息,当前登录时间或者你可能会记录其他什么
比如用户浏览了什么东西。

token流程,生成一段随机字节作为令牌,服务器可以根据令牌找到令牌持有者,
随着时间的推移,旧令牌会被新令牌取代。

那么这就有个问题,服务器端需要存储令牌对应的信息,如果是关系型数据库,那么就会对关系型数据库的开销增大,虽然有批量增加,但用户的操作改变的数据库行不多,所以基本没用,这个时候呢,就需要使用redis来替代关系型数据库了。

使用redis的散列用存储令牌和用户的映射,我喜欢叫散列为hash哈哈
这里使用伪代码来操作
这里不添加过期代码,可以自行拓展

//用户登录成功后根据令牌获取用户信息
public user getUserByToken(String,token){
   
       User user = jedis.hget("login:",token);
       return user;
}

更新这些信息并不难,因为需要验证token的时候就会执行相应操作
比如添加用户的浏览记录
还是写伪代码

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值