浅谈跨域多点SSO(多注册服务器的SSO)

多点SSO,我们这里可以理解为有多个注册服务器的SSO,也可以理解为分布式SSO,也即是用户的注册信息是分布在多台服务器上的,这类技术其实在现在来说是相对比较成熟的,比如tencent,skepy,互联星空等等大型的应用,比如Tencent的号码上亿,如果用一台服务器集中存储或者是只用一个群集来集中认证,那么所带来的漫长的等待是我们所不能忍受的。所以我们需要多点SSO。不过窃以为Tencent的QQ从技术上不应该用多点SSO来表述,而且实质上也不是SSO技术,而是Tencent自己的P2P协议来完成的。就自己的经验看来,其实多点SSO(着重是实现跨域服务器之间的分布式SSO)最好的例子应该是互联星空平台,限于保密协议的关系我们不继续讨论互联星空,我们来说多点的SSO。

就技术上来说,多点SSO存在一下几点难题:

  1. 多个注册服务器间的用户认证标示防止重复
  2. 用户注册地址的定位
  3. 跨域的认证状态同步(所有SSO都要解决的问题)
  4. 注销登录状态的问题

对于第一点,一般来说可以借鉴SIP协议的方式。我们将用户的ID分成两段,前一段是注册站点内的ID然后在@后是网站的域名,结构上和Email地址差不多譬如Alexander-lee@cnblogs.com,假设cnblogs.com就是我注册的站点,在注册的时候我只需要输入Alexander-lee,然后自动在尾巴上给我加上@cnblogs.com。这样子每个站点注册的时候限制就可以达到最小。

同时,这个方式还可以达到定位用户注册服务器地址的作用,我们可以使用后面的域名信息来定位用户的注册位置,还是Alexander-lee@cnblogs.com,识字的人看到都知道在cnblogs.com注册的。

然后是跨域认证状态同步的问题。这个在拙作http://www.cnblogs.com/Alexander-Lee/archive/2007/01/27/631962.html中已经描述的很清楚,也是大多数SSO所采用的做法(个人不建议使用跨域Cookie或者js注入等技术,都容易被严格点的浏览器挡获)。

最后是注销登录状态的问题,这个在我原来的Post里面没有提到,对于单点SSO来说还算是比较简单的。但是对于多点SSO来说确是比较烦琐的事情了,因为需要清除多个服务器上的Cookie,还不能借助JS等客户端技术来完成的。最简单的方式就是所有站点全部使用非持久的Cookie,关闭浏览器就全部都失效了。但是如果是持久Cookie的话,个人来说还没有很好的主意,有一个想法就是在协议里规定一个Cookie用来存储所有登录过的服务器,然后在注销的时候一次一次的转跳到注销的接口页面(笨办法,期待高人给出比较简单的解决方案)。

其实写这些东西是因为看了http://www.cnblogs.com/chinaxiaofei/archive/2007/09/28/909920.html 这位高手的Post,看后感觉有很多问题没有谈到,也不是很完善,所以发此贴期待共同讨论。

当用户第一次访问web应用系统1的时候,因为还没有登录,会被引导到认证中心进行登录;根据用户提供的登录信息,认证系统进行身份效验,如果通过效验,返回给用户一个认证的凭据;用户再访问别的web应用的时候就会将这个Token带上,作为自己认证的凭据,应用系统接受到请求之后会把Token送到认证中心进行效验,检查Token的合法性。如果通过效验,用户就可以在不用再次登录的情况下访问应用系统2和应用系统3了。所有应用系统共享一个身份认证系统。认证系统的主要功能是将用户的登录信息和用户信息库相比较,对用户进行登录认证;认证成功后,认证系统应该生成统一的认证标志,返还给用户。另外,认证系统还应该对Token进行效验,判断其有效性。 所有应用系统能够识别和提取Token信息要实现SSO的功能,让用户只登录一次,就必须让应用系统能够识别已经登录过的用户。应用系统应该能对Token进行识别和提取,通过与认证系统的通讯,能自动判断当前用户是否登录过,从而完成单点登录的功能。 比如说,我现在有3个分站点和1个认证中心(总站)。当用户访问分站点的时候,分站点会发Token到验证中心进行验证。验证中心判断用户是否已经登录。如果未登录,则返回到验证中心登录入口进行登录,否之则返回Token验证到分站点,直接进入分站点
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值