sso单点登录系统的理解

单点登录有两种方式,一种是跨域,一种是不跨域。

一:在不跨域的情况下,

只需要将cookie设置为顶域状态,即可以实现cookie的共享。
在这里插入图片描述

二:跨域登录

在这里插入图片描述

用户访问app系统,app系统是需要登录的,但用户现在没有登录。
SSO登录系统。 SSO系统也没有登录,弹出用户登录页。
用户填写用户名、密码,SSO系统进行认证后,将登录状态写入SSO的session,浏览器(Browser)中
   写入SSO域下的Cookie。
SSO系统登录完成后会生成一个ST(Service Ticket),然后跳转到app系统,同时将ST作为参数传递
   给app系统。
app系统拿到ST后,从后台向SSO发送请求,验证ST是否有效。
验证通过后,app系统将登录状态写入session并设置app域下的Cookie。

至此,跨域单点登录就完成了。以后我们再访问app系统时,app就是登录的。接下来,我们再看看访问app2系统时的流程。

用户访问app2系统,app2系统没有登录,跳转到SSO。
由于SSO已经登录了,不需要重新登录认证。
SSO生成ST,浏览器跳转到app2系统,并将ST作为参数传递给app2。
app2拿到ST,后台访问SSO,验证ST是否有效。
验证成功后,app2将登录状态写入session,并在app2域下写入Cookie。

这样,app2系统不需要走登录流程,就已经是登录了。SSO,app和app2在不同的域,它们之间的session不共享也是没问题的。

这里有个关键的地方,如何知道登录app2的用户就是app1的用户,因为在sso系统下有cookie,当app1登录的时候,会记录下一个cookie(cookie的value是一个ST),当app2没有登录的时候,跳转sso系统,sso系统查询得到自己的cookie,即用户已经登陆了sso系统了,就将sso系统中的ST返回给app2,这样就知道了,登陆app2的用户是app1了

至于跨域中服务端的ST,可以放在redis中,与用户名连成一个map,这样在验证服务端的ST是正确之后,可以返回用户名,直接登录app系统。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值