php redis 鉴权,使用token机制做登录鉴权(threadlocal+redis)

登录流程:

一:登录成功后:

1,根据userId生成token,放入redis中 key为token,value为用户信息进行存储。

2,response token到前端的cookie中

3,threadlocal中存储user 信息

二:拦截器:

1,通过request获取前端的cookie,check token(有两个token ,token2根据token1生成)

2,token不为空的话,去redis中拿token为key查询user信息,如果user为空,直接返回false.

3,user不为空,刷新threadlocal中的user info,同时刷新redis中token : user的过期时间

扩展思路:

问:如果想实现一个账号如果被第二个人登录,第一个登录的会被顶掉,有思路吗:

redis : userId -> token

token -> user

我这样想的:登录succ->生成唯一token->redis存 userId:token ,token:user 。拦截器根据redis的token key 进行判断user是否为null;

如果第二个人登录此账户,同样的生成一个唯一token,根据userId查出redis中的所有token,然后遍历删除token:user。重新设置新的token:user

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值