12.单点登录的实现原理

(1)共享Session
将用户认证信息保存在Session中,即以Session内存储的值为用户凭证。
解决方案:使用基于Redis的Session共享方案,将Session存储在Redis上,将整个系统的全局Cookie Domain设置于顶级域名上,这样SessionID就能在各个子系统间共享。
存在限制:
1.Session中所涉及的类型必须是子系统中共同拥有的。
2.跨顶级域名的情况完全无法处理。

(2)基于OpenId的单点登录
将用户的身份标识信息简化为OpenId存放在客户端,当用户登录某个子系统时,将OpenId传送到服务端,服务端根据OpenId构造用户验证信息,多用于C/S与B/S相结合的系统。
1.当用户第一次登陆时,将用户名密码发给验证服务;
2.验证服务将用户标识OpenId返回到客户端;
3.客户端进行存储;
4.访问子系统时,将OpenId发送到子系统;
5.子系统将OpenId转发到验证服务;
6.验证服务将用户认证信息返回到子系统;
7.子系统构建用户验证信息后将授权后的内容返回给客户端。
(3)基于Cookie的OpenId存储
1.在提供验证服务的站点里登录;
2.将OpenId写入顶级域名Cookie里;
3.访问子系统(cookie带有OpenId);
4.子系统取出OpenId通过验证服务发送OpenId;
5.返回用户认证信息;
6.返回授权后的内容。
和共享Session方案相比,用OpenId解耦了Session中所涉及的身份类型必须是子系统中共同拥有的缺陷。
(4)B/S多域名环境下的单点登录处理
1.用户通过登录子系统进行用户登录;
2.用户登录子系统记录了用户的登录状态、OpenId等信息;
3.用户使用业务子系统;
4.若用户未登录业务子系统则将用户跳转至用户登录子系统;
5.用户子系统通过JSONP接口将用户OpenId传给业务子系统;
6.业务子系统通过OpenId调用验证服务;
7.验证服务返回认证信息、业务子系统构造用户登录凭证;(此时用户客户端已经与子业务系统的验证信息已经一一对应)
8.将用户登录结果返回用户登录子系统,若成功登录则将用户跳转回业务子系统;
9.将授权后的内容返回客户端;
(5)安全问题
采用单用户多OpenId的解决方案,每次用户通过用户名/密码登陆时,产生一个OpenId保存在Redis里,并且设定过期时间,这样多个终端登录就会有多个OpenId与之对应,不再会存在一个OpenId失效所有终端验证都失效的情况。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值