基于cookie-redis实现单点登录的原理浅谈

原文转载https://blog.csdn.net/u012878380/article/details/53997108

sso俗称单点登录: 分布式项目中要实现在一个项目中登录之后其他与之有关联的项目就不要在登录了这个过程就叫单点登录

实现单点登录的方式有很多种  我们选择的是基于cookie-redis方式实现的。此种实现方式是模拟cookie-jssesion。所以要想先明白cookie-redis还是先明白cookie-jsession吧

一session原理(存放在在服务器端,每次请求会重置时间)

    当客户端发送一个请求的时候服务器端会判断是否有一个名为jsesion的cookie。

           如果没有的话就会创建一个名为jsession的cookie。cookie的值为uuid,同时会创建一个uuid为key的session被创建出来。同时会把名为jsession的cookie返回到客户端

           如果有的话么cookie有没有超时再次请求的时候就直接会将名为jsession的cookie返回到请求头中。

二cookie原理(存放在客户端,每次请求不会重置时间)

           在服务器端实例化cookie对象只能存字符串。

   设置cookie的有限时间以及作用域和有效路径

           跟随响应对象响应给客户端

           浏览器接收带cookie之后,会对其进行io操作存放到本地的某个文件夹中、

           当用户再次发请求的时候 只要能获取某个或者某些cookie,浏览器就会自动发送到客户端

好了现在cookie-session理解之后我们来探讨一下sso中的cookie-redis吧

第一步

要想实现cookie-redis总得有个cookie吧,所以第一步要先创建一个cookie,然后cookie起个名字,(因为我们要判断浏览器端是否存在这个cookie所以说需要专门写一个js这个js 是前台写的,跟后续其他的需要登录的网页相关联,其他的网页要引入这个js,当判断cookie有了之后就会将这个js就会获取第一个js里面的cookie值,之后就可以从redis查询数据了)cookie的值为uuid,然后将这个uuid作为key存储到redis中他的值为用户信息,同时设置redis的失效时间。

第二步

每一个需要用户信息的页面都要有两个js上面提到的,第一个js要判断是否存在这个cookie,第二个js是先获取cookie里面的值然后发送一个jsonp请求,从redis里面获取,然后进行相应的展现。

总结redis-cookie就是对cookie-jsessin的模拟。实现sso主要用到的有 

1. cookie

2. 第一个js获取名为指定值得cookie信息

3. 第二个js需要判断cookie是否存在以及将cookie的值给jsonp

4. 由jsonp发送请求判断是redis是否存在 

5. spring里面专门提供了一个接口可以返回jsonp需要的这个类交mappingjaskonvalue

6. 在redis里面查询。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
基于Redis单点登录方案可以通过以下步骤实现: 1. 用户登录:用户在登录页面输入用户名和密码,向认证服务器发送登录请求。 2. 认证服务器校验:认证服务器校验用户名和密码是否正确,如果正确,生成一个唯一的Session ID作为标识用户身份,并将其存储到Redis中。同时,认证服务器将Session ID返回给客户端。 3. 客户端存储Session ID:客户端收到Session ID后,将其存储在Cookie中或者存储在本地,以便后续请求时使用。 4. 客户端向微服务发送请求:客户端向微服务发送请求时,在请求头或者请求参数中携带Session ID。 5. 微服务校验Session ID:微服务在接收到请求时,校验Session ID的有效性,如果有效,则返回资源给客户端;否则,返回401未授权状态码。 需要注意的是,为了保证Session ID的安全性,应该对Session ID进行加密处理。同时,为了减轻Redis的压力,应该设置Session ID的过期时间,避免不必要的资源浪费。 基于Redis单点登录方案具有以下优点: 1. 高性能:Redis是一个高性能的内存数据库,可以快速地存储和查询Session ID信息。 2. 高可用性:Redis支持主从复制和哨兵机制,可以保证数据的高可用性和容错性。 3. 可扩展性:Redis可以通过集群部署来实现扩展,可以满足高并发的访问需求。 4. 易于实现Redis提供了丰富的API和工具,可以方便地实现Session管理和过期处理。 需要注意的是,在使用Redis进行单点登录时,需要注意Redis的安全性和稳定性,避免Redis被攻击或者发生故障。因此,在部署和配置Redis时,需要采取安全措施和容错措施,以确保系统的安全性和可靠性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值