热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

java完全跨域sso_跨站(跨域)单点登录的实现(SSO)

本文分两部分1.转他人的文章,详细介绍了跨站单点登录的原理和解决方案2.我自己写代码,着重介绍里面的重点部分1:假设我们需要在以下这些站之

本文分两部分

1.转他人的文章,详细介绍了跨站单点登录的原理和解决方案

2.我自己写代码,着重介绍里面的重点部分

1:

假设我们需要在以下这些站之间实现单点登录

www.onmpw1.com

www.onmpw2.com

www.onmpw3.com

对于这种情况,我们有两种实现方式,其中我们先来介绍实现比较简单的方式。

方式一

为了实现单点登录,当用户登录其中的任何一个站点时,我们需要针对其他每个站点在浏览器端设置COOKIE信息。

如果用户在onmpw1站点进行登录,登录成功授权以后,浏览器将会存储一份儿onmpw1站点的COOKIE信息。同时,为了可以登录onmpw2和onmpw3,我们需要在设置onmpw1的COOKIE的同事也对onmpw2和onmpw3进行COOKIE设置。因此在对onmpw1进行响应之前,我们需要先跳转到onmpw2和onmpw3站点去设置COOKIE信息。

3b5ce6e25755?from=groupmessage

下图是对于两个站点的单点登录模型(三个的图画起来比较麻烦,为了节省时间,就用两个来表示,但是原理是相同的)

3b5ce6e25755?from=groupmessage

此种情况的验证步骤是这样的:

一、用户向www.onmpw1.com(以下简称onmpw1)请求一个需要验证的页面。

[状态: 浏览器还没有验证的COOKIE信息]

二、浏览器向onmpw1发送请求(该请求没有COOKIE信息,因为它还没有存储所属域为onmpw1.com的COOKIE信息)。

[状态: 浏览器还没有验证的COOKIE信息]

三、onmpw1发现在请求中没有带COOKIE信息,所以它将请求重定向到登录页面

[状态: 浏览器还没有验证的COOKIE信息]

四、用户提交了登录所需验证的信息并且点击登录按钮,浏览器发送一个post请求到onmpw1。

[状态: 浏览器还没有验证的COOKIE信息]

五、onmpw1收到提交的验证信息,开始验证这些信息。如果验证成功,则标记该用户已经登录。然后会创建带有登录用户信息的COOKIE,并将其加入响应信息中。

[状态: 浏览器还没有验证的COOKIE信息]

六、onmpw1暂时还不去响应浏览器的请求。这时它将会向浏览器发送重定向到www.onmpw2.com(以下简称onmpw2)的命令,并且还带有在onmpw2站点需要返回的url地址,该地址为最初onmpw1中的。因为COOKIE信息已经在响应信息中,所以这个COOKIE也被发送给浏览器了。

[状态: 浏览器还没有验证的COOKIE信息]

七、浏览器接收道带有验证的COOKIE信息和重定向到onmpw2的命令的响应信息以后,将COOKIE信息的域设置为onmpw2存储到本地,并且想onmpw2发送请求。这个请求中会带有刚才的COOKIE信息。

[状态:浏览器中已经有所属域为onmpw2的COOKIE信息]

八、onmpw2立刻会重定向到需要返回的url地址,并且通过读取浏览器发送的COOKIE信息,获取到onmpw1的COOKIE。并将这COOKIE也一同发送给浏览器。

[状态:浏览器中已经有所属域为onmpw2的COOKIE信息]

九、浏览器在接受到这些信息以后,会将所属域为onmpw1的COOKIE存储在本地。并且再次向onmpw1发送一个带有COOKIE信息的请求。

[状态:浏览器中已经有所属域为onmpw2和onmpw1的COOKIE信息]

十、onmpw1接收到验证信息以后,知道验证COOKIE已经设置成功。此时onmpw1会返回相应的请求界面,而不再是登录界面。

[状态:浏览器中已经有所属域为onmpw2和onmpw1的COOKIE信息]

所以说,当用户再次访问onmpw2的时候,COOKIE信息已经存储到浏览器中了。这时onmpw2会在COOKIE中读取到登录的用户的信息,然后提供相应的界面给浏览器。

这样,单点登录就已经设置成功了。在本例中,按照上述步骤,登录onmpw1以后,onmpw2和onmpw3就可以同时实现登录了。

如何退出登录

既然我们已经实现了单点登录,但是我们还得考虑退出的问题。既然是同时登录的,那总不能在退出的时候一个一个的退出吧!所以说我们还要设置单点退出。

要想实现单点退出,在本例中,我们需要做的是当在一个站点退出的时候,其他两个站点的COOKIE同样也需要在浏览器中清除。这样才可以实现单点退出。

这样其实也很简单,在理解了上述单点登录的流程以后,单点退出只是按照上面的步骤将设置验证COOKIE改成从响应信息中移除COOKIE就可以实现了。

对于这种情况,不管是单点登录也好,还是单点退出。都存在一个问题,在本例中我们只是有三个站点。如果说我们整个系统有10个20个或者更多站点,那像我们这样来回的重定向会很影响效率。

方式二

接下来我们来介绍另一种方式。这种方式需要我们借助一个单独的SSO服务,专门做验证用。而且我们还需要对于不同的站点的用户要有一个统一的用户数据。相对于前一种方式——浏览器需要存储每个站点的COOKIE——来说,这种方式浏览器只需要存储SSO服务站点的COOKIE信息。将这个COOKIE信息用于其他站点从而实现单点登录。我们暂且将这个SSO服务站点成为www.SSOsite.com(以下简称SSOsite)。

在这种模型下,针对任何站点的请求都将会先重定向到SSOsite去验证一个身份验证COOKIE是否存在。如果存在,则验证过的页面将会发送给浏览器。否则用户将会被重定向到登录页面。

3b5ce6e25755?from=groupmessage

为了理解此种方式,现在假设我们来运用这种模型实现以下两个站点的单点登录。

www.onmpw1.com(以下简称onmpw1)

www.onmpw2.com(以下简称onmpw2)

并且我们还有一个专门用来进行验证的服务站点www.SSOsite.com(以下简称SSOsite) 。

第一部分

3b5ce6e25755?from=groupmessage

实现流程

·用户请求onmpw1的一个需要验证的页面

·onmpw1向浏览器发送重定向到SSOsite的命令。并且在地址中添加一个返回地址(ReturnUrl)参数query string,该参数的值就是最初向onmpw1请求的地址。

·SSOsite会在请求中检查是否有身份验证COOKIE,或者任何用户token。没有这些信息,则会再次重定向到onmpw1,在重定向到onmpw1中的请求中会带有参数让用户登录的url参数和最初的浏览器请求onmpw1的地址——ReturnUrl。

·onmpw1会检测从SSOsite重定向来的请求的参数。这时onmpw1了解到该用户需要登录,因此onmpw1会重定向到登录界面,并且通知浏览器该请求不用再重定向到SSOsite。

第二部分

3b5ce6e25755?from=groupmessage

·用户提供了身份验证信息并且点击了登录按钮。现在不会再去重定向到SSOsite。这时,onmpw1调用SSOsite 中的web/WCF服务去检查用户提供的身份验证信息。成功验证,会将带有token属性的用户对象返回给onmpw1。而这个token是每一次用户登录都会生成的。

·onmpw1标记用户已经登录成功,然后会生成一个URL地址,该地址会带有用户token,重定向到SSOsite。

·SSOsite检查收到的URL地址,会在其中发现用户token。通过该token可以知道用户已经成功登录onmpw1了,所以SSOsite需要准备验证的COOKIE信息。因此,它会使用token在缓存中取出用户信息来生成COOKIE信息,而且还会在COOKIE中设置一些其他的信息(例如过期时间等)。然后把COOKIE加入到响应信息中。最后重定向到最初的ReturnUrl地址。同时token还是要被加在query string中带过去的。

·浏览器得到重定向到onmpw1的命令,并且从SSOsite中得到COOKIE信息。因此浏览器将所属域为SSOsite的COOKIE保存在本地。然后带着token去请求onmpw1。

·现在onmpw1看到用户token在query string 参数中,然后会再次通过web/WCF服务去在SSOsite上验证token。验证成功以后会将最初刚开始请求的页面发送给浏览器用于向用户输出。

第三部分

3b5ce6e25755?from=groupmessage

·用户现在去请求onmpw2。

·onmpw2重定向到SSOsite,同样设置ReturnUrl为刚开始请求的onmpw2的页面地址。

·浏览器接收到重定向的命令以后,因为本地存在SSOsite的COOKIE,所以会COOKIE加到请求中发送给SSOsite。

·SSOsite检查接收到的请求中发现有COOKIE信息,首先会检查该COOKIE信息是否过期,如果没有过期,将会从COOKIE中提取出用户token。然后带着token重定向到最初的onmpw2中的地址。

·onmpw2发现请求中有用户token,然后他会通过SSOsite的web/WCF服务验证token的合法性。验证成功以后,将最初浏览器请求onmpw2的页面发送给浏览器用以向用户输出。

总结

哇哦,看起来有很多东西需要做。其实并没有那么复杂。

起初,浏览器没有所属域为SSOsite的COOKIE信息。因此无论是点击任何站点的需要验证的界面都会跳转到登录页(这个过程是由程序内部重定向到SSOsite来检查是否存在COOKIE的)。一旦用户登录成功,所属域为SSOsite的,并且带有登录用户信息的COOKIE会被浏览器存储在本地。

然后,当用户再次访问需要验证的页面的时候,同样请求会在被重定向到SSOsite,并且浏览器会带上先前已经保存的COOKIE信息。SSOsite检索COOKIE,从中提取出用户token,并带着这个token重定向到最初请求的站点页面。然后该站点会通过web/WCF服务去验证token的合法性。然后将相应的页面发送给客户端。

一旦用户通过该单点登录模型登录到站点上,请求任何需要验证的页面都会内部重定向到SSOsite验证COOKIE和提取用户token,然后将请求的页面发送给浏览器输出。

2:

上面的两个方案,重点都是带着参数(可能是URL,可能是token)重定向到另一个域名下,

去请求这个域名下的应用程序,然后应用程序在新域名下生成COOKIE或者token,

然后再带着Token(方案一之生成COOKIE,不带TOKEN)重定向回去。

下面我用PHP代码模拟下

www.a.com    这个域名下有文件login.php 内容如下

if(!array_key_exists('jump',$_GET)){setCOOKIE("login",1);header('Location: http://www.b.com/login.php?jump');}

(图1)

www.b.com    这个域名下也有个程序文件index.php(其实名字随意) 内容如下

if(array_key_exists('jump',$_GET)){setCOOKIE("login",1);header('Location: http://www.a.com/login.php?jump');}

(图2)

一开始,用户在这两个域名下,未登录的话都是没COOKIE的。

此时用户先访问 a域名的login.php,登录a成功之后执行上面图1的代码,

并没有jump这个参数(图2说这个参数的作用),所以设置login成功,并用header重定向到了www.b.com/login且带着jump参数

当b下的login.php收到jump过来的参数时,说明是a登录成功过来的,那么b下的程序就直接设置COOKIE为 login=1

(此时因为已经到了b域名下执行的应用程序,所以COOKIE的有效域为www.b.com)

之后再由b再重定向到 a域名,带着jump参数,这样a就不会再跳转到b下了。

此时,www.a.com和www.b.com这两个域名下,都有了登录状态的COOKIE。

用户无论去那个站,都不用再登录了。

方式一的原理即以上

方式二略

这两个的重点,都是重定向到新域名之后生成新域名的COOKIE,然后再重定向回来



推荐阅读
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • http:my.oschina.netleejun2005blog136820刚看到群里又有同学在说HTTP协议下的Get请求参数长度是有大小限制的,最大不能超过XX ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • 在重复造轮子的情况下用ProxyServlet反向代理来减少工作量
    像不少公司内部不同团队都会自己研发自己工具产品,当各个产品逐渐成熟,到达了一定的发展瓶颈,同时每个产品都有着自己的入口,用户 ... [详细]
  • 基于PgpoolII的PostgreSQL集群安装与配置教程
    本文介绍了基于PgpoolII的PostgreSQL集群的安装与配置教程。Pgpool-II是一个位于PostgreSQL服务器和PostgreSQL数据库客户端之间的中间件,提供了连接池、复制、负载均衡、缓存、看门狗、限制链接等功能,可以用于搭建高可用的PostgreSQL集群。文章详细介绍了通过yum安装Pgpool-II的步骤,并提供了相关的官方参考地址。 ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • PHP图片截取方法及应用实例
    本文介绍了使用PHP动态切割JPEG图片的方法,并提供了应用实例,包括截取视频图、提取文章内容中的图片地址、裁切图片等问题。详细介绍了相关的PHP函数和参数的使用,以及图片切割的具体步骤。同时,还提供了一些注意事项和优化建议。通过本文的学习,读者可以掌握PHP图片截取的技巧,实现自己的需求。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • 阿,里,云,物,联网,net,core,客户端,czgl,aliiotclient, ... [详细]
  • ZSI.generate.Wsdl2PythonError: unsupported local simpleType restriction ... [详细]
  • Webmin远程命令执行漏洞复现及防护方法
    本文介绍了Webmin远程命令执行漏洞CVE-2019-15107的漏洞详情和复现方法,同时提供了防护方法。漏洞存在于Webmin的找回密码页面中,攻击者无需权限即可注入命令并执行任意系统命令。文章还提供了相关参考链接和搭建靶场的步骤。此外,还指出了参考链接中的数据包不准确的问题,并解释了漏洞触发的条件。最后,给出了防护方法以避免受到该漏洞的攻击。 ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
author-avatar
_红裙子_Supreme
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有