php单点登录

本文介绍了使用PHP实现单点登录系统的过程,包括系统流程、用户登录和退出的逻辑,以及涉及的数据库连接和Redis存储全局会话状态。通过代码示例展示了如何在不同应用系统间共享认证信息,实现用户在多个系统间的无缝切换。
摘要由CSDN通过智能技术生成

今天公司让我实现一套单点登录系统,参考了一下有关资料和以往公司所做的项目,先实现一个比较简单的可扩展的单点登录系统。

首先默认有三个系统,第一系统当然是最为重要的认证系统,或者叫做认证中心。其次有两个应用系统,应用系统A和应用系统B。当然,应用系统可以扩展更多CDEFG等等。首先来看看整个系统的流程。

1. 首先用户向应用系统A发送请求,系统A会检查自己和用户的会话状态,我管这个状态叫局部会话状态。各个应用系统会维持好各自的局部会话状态,用以检查用户是否已经登录。如果检查局部状态发现用户已经登录,则不需要向认证中心发送请求,直接显示用户为登录状态。

2. 若局部状态为未登录状态,则系统A将用户请求重定向到认证中心进行认证。若是用户之前在认证中心认证过,在重定向时会同时提交之前的认证信息。若是没有认证或是认证信息会话已过期,则认证中心跳转到登录页面重新进行登录验证。在验证中心维持了一个全局的会话状态。

3. 认证成功之后,认证系统会在本地保存全局的会话状态,然后再请求重新定位到referer也就是之前的A站的连接,并附带上验证相关的信息。此时系统A将验证信息保存为局部会话状态。这样在局部会话存在期间,用户每次访问系统A就不再需要重复向认证中心提交认证请求了。

4. 用户如果再去访问应用系统B,其流程也一样,系统B发现本地没有该用户的局部会话状态,然后将用户的请求重定向的认证中心进行登录认证,之后认证系统再将认证信息转发给应用系统B,应用系统B将用户的认证信息保存为局部会话状态,这样,用户就可以实现单点登录了。

当用户推出登录的时候各个应用系统的局部状态和认证系统的全局状态也必须进行撤销。比如当用户在应用系统A退出登录,则系统B有关该用户的局部会话必须清除,认证中心的全局会话也必须清除。流程大概如下。

1.用户在应用系统A点击退出,系统A清除该用户会话信息,并向认证中心发送请求。

2.用户中心接受到请求,清除该用户的全局会话状态,并向其他应用系统主动发送请求,要求各应用系统清除本机上有关该用户的局部会话状态。此时就要求认证中心维护这一个应用系统的列表,里面记录了每个应用系统的地址的信息。

3.各应用系统接收到认证中心的请求,随机清除该用户的局部状态信息,这个用户从某个系统上退出,其他系统也同样退出了登录的状态。

其实这个单点登录系统就好比是服装店的会员卡制度一样,想象一下回到还没有互联网只有电话通信的年代。比如现在某个特别繁华的城市市开了两家gucci的品牌店。而gucci公司总部位于市中心,其他分店分别位于市区的东西四两边。若是一天,一个叫christine的美女进入东部的店,营业员tracy很热情的对这位美女说:“美女,请问您是gucci的会员吗?如果是,可以享受8折的优惠。如果不是,可以当日办理,同样可以享受到8折。”christine一听立马表示想要成为会员。但成为会员需要向总部提交申请,于是tracy打电话去向公司总部申请,电话里,christine提交了个人的身份信息,身高体重,年收入等等。接着总部那边说:“好的,christine小姐,恭喜您正式成为gucci的VIP会员,您可以立马享受到8折购物的优待。”此时,营业员tracy也将christine小姐的信息记录在店里面。christine买了一个gucci的围巾满意的回家了。又过了一个月,christine又来到东边的这家店,想买一个包包,tracy今天休息,营业员换成了sally,christine告诉sally自己是VIP会员。sally,查了一下本店的记录,christine确实是VIP会员,所以可以享受8折购物优待。可不巧christine今天忘记带钱包了,所有也没有买包包,跟sally说了声抱歉。又过了半个月christine又去了西边的一家店,告诉店员mimi她是gucci会员,mimi查看了一下本店会员表里没有christine的名字,然后告诉christine本店没有她的信息,但mimi又让christine稍等一会,她打个电话去总部问问,然后总部告诉mimi,一个半月前christine小姐已经注册过会员了,并要求mimi立即将christine的信息记录在册,这样,christine的信息也被记录在西边的店。这样,以后christine无论去西边还是东边的店买东西,都不用再向总部登记也不用店员打电话询问,因为俩家店里都记录了christine的会员信息。

这个例子其实也不够完美,很多地方也有待改进,但大概能表达个意思。大概流程说玩了,现在就具体把这个单点登录系统架设起来,并写点代码试试。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值