面试-----分布式应用的登录校验解决方案有哪几种

24 篇文章 0 订阅

 ==分布式应用的登录校验解决方案有哪几种==

   方案一:
     真实的应用不可能单节点部署,所以就有个多节点登录session共享的问题需要解决
    tomcat支持session共享,但是有广播风暴;用户量大的时候,占用资源就严重,不推荐
   方案二:
     使用redis存储token:
        服务端使用UUID生成随机64位或者128位token,放入redis中,然后返回给客户端并存储在cookie中
       + 用户每次访问都携带此token,服务端去redis中校验是否有此用户即可
  方案三(推荐):
      JWT( json wen token)
     什么是JWT?
      JWT 是一个开放标准,它定义了一种用于简洁,自包含的用于通信双方之间以 JSON 对象的形式安全传递信息的方法。 可以使用 HMAC 算法或者是 RSA 的公钥密钥对进行签名
       简单来说:**就是通过一定规范来生成**token,然后可以通过解密算法逆向解密token,这样就可以获取用户信息
     优点:
       生产的token可以包含基本信息,比如id、用户昵称、头像等信息,避免再次查库
       存储在客户端,不占用服务端的内存资源
     缺点:
       token是经过base64编码,所以可以解码,因此token加密前的对象不应该包含敏感信息,如用户权限,密码等
       如果没有服务端存储,则不能做登录失效处理,除非服务端改秘钥

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

多年码龄的小白

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值