- 浏览: 2620398 次
- 性别:
- 来自: 小胖儿的大城
文章分类
最新评论
-
ni4wangba0:
ni4wangba0 写道亲测,算法有问题。对不起,其实是我自 ...
谈谈"求线段交点"的几种算法(js实现,完整版) -
ni4wangba0:
亲测,算法有问题。
谈谈"求线段交点"的几种算法(js实现,完整版) -
kers007:
苹果不让Webapp 在appstore 里发布,我不知道对 ...
苹果真的要在 AppStore 里封杀 WebApp 吗? -
striveandlive:
fins = js大牛
[原创]GT-Template, 一个超轻量级的js模板工具. -
AlwaysYang:
基础扎实的才能行走天下。
关于body的"大小"在ie和ff下的一些基础知识
最近写了一个简单的单点认证系统(更喜欢称它为组件)
由于刚涉及sso不久,对他还不是很了解(不了解也敢写组件? 呵呵 见笑了)
所以问题再所难免,系统大家能够给予指正和帮助,先谢谢了.
下面贴一下简单的说明文档, 里面不牵涉技术细节,只是我对它的一个简单的描述
看看设计上有什么地方需要改进没
在过几天,根据大家对它的建议和意见 做些改善后 再把代码和详细的使用配制方法贴上来.
(比较长 不好意思了)
==========================================
组件名称:S3O
一套轻量级的、简单易用的、高效的单点认证系统。
当然同样具有一定的安全性,也支持跨域。
S3O: Simple Single Sign-On ----> SSSOS
一个简简单单的单点认证组件,
既然 WWWC 叫做 W3C ,那自然SSSO也可以叫S3O了
=====================================
系统特性:
=====================================
1 基于http协议
2 支持跨域认证
3 各个子应用采用自己的登录入口,并且拥有独立的授权模块
4 支持子应用间的同步
5 重要信息加密后,通过hessian传递,并使用一次性ticketKey,安全性可以得到一定的保障。
6 绝对轻量级
7 基本原理应该(因为我没读过CAS的源代码,只看过一些相关文章,所以不敢肯定)类似CAS的基本模式(而不是它的代理模式).
( 当然要比CAS简单while(true){很多}了。 )
8 基于spring 和 hessian技术构建。缓存采用ehcache。
=====================================
术语解释:
=====================================
子应用:
就是需要提供单点登录的各个应用。
认证中心:
单点登录的认证中心。它也是个web应用。
可以把它理解为一个存放用户名和密码的公共空间,
各个子应用可以从它这里取用户名和密码,然后调用各自的授权模块对用户进行授权。
在该单点登录系统中,认证中心并不提供授权服务。
认证中心在客户端的cookie:
用于存放ticket的cookie。各个子应用的cookie不能在跨域的子应用之间共享,所以需要认证中心的cookie存放数据。
ticket:
认证中心生成的一个具有唯一性的标识,作为键,用来在认证中心缓存中保存登录用户的信息
同时ticket还将存放在认证中心在浏览器端的 cookie内
ticketKey:
认证中心生成的一个具有唯一性的标识,作为键,用来在认证中心缓存中保存ticket。
它是一次性的,当以ticketKey为键,从认证中心缓存中读取一次ticket后,该键将失效。
ticketKey会通过http在子应用与认证中心之间传递。
service:
通常指的是hessian service。
通过开源组件hessian发布的一种类似web service的远程服务。
serverMethod:
也是一种发布的远程服务,但调用方法是通过url调用。
可以理解为类似struts的dispatch action的实现。
(
就好像用下面的url访问dispatch action, 会自动执行action中的query方法一样
http://www.aaa.com/example.do?actionMethod=query
)
客户端浏览器、子应用、认证中心之间 就是通过各种service和serverMethod进行通讯的。
=====================================
单点登录主要流程概述:
=====================================
判断用户是否已经登录:
当前子应用的session中有用户的基本信息,同时当前子应用的全局缓存中也有该用户的基本信息。
则认为该用户已经在当前系统中登录。两个条件缺一不可。
==================================================
系统初始化流程:
1 启动认证中心(一个web应用)并进行相关的初始化(初始化filter、缓存、发布service等)
2 启动各个子应用(初始化filter、缓存、发布service等)
3 子应用通过hessian 向 认证中心 注册自己的信息(包括 子应用的url 子应用中发布的service等信息)
4 认证中心验证子应用是否有合法的key,没有合法的key,则不允许注册。
5 成功注册的子应用的信息会加入 认证中心的子应用信息列表内(一个全局缓存)
这个列表可以帮助认证中心向各个子应用来发广播,也可以用来在各个子应用间进行通讯和同步.
=====================================
登录流程
(假设登录A应用 登录的用户为 tom )
1 通过A应用的登录页面输入用户名tom 以及 密码
2 调用A应用的授权模块进行授权,授权失败返回登录页面。
3 授权成功,则将用户名 密码(加密后)通过hessian 发往 认证中心。
4 认证中心对其进行缓存,并产生ticket,将ticket和用户基本信息放入认证中心的缓存
5 同时还将生成ticketKey,以ticketKey做为键,把ticket放入认证中心端的一个临时的缓存内。
6 将ticketKey通过hessian返回给A应用。
7 A应用得到ticketKey后,通过内部redirect访问认证中心的指定url,该url用于产生cookiet
(该cookie为认证中心在客户端产生,cookiet内存放ticket)。
8 完成写cookie操作后 ,清楚临时缓存中的ticketKey和ticket。
9 以上步骤成功完成后,将在A应用session和全局缓存中放置用户的基本信息(用户名 ticket)。
此时,对于a应用来说,用户tom的状态为已登录.
=====================================
登出流程
(假设登出A应用,登出的用户为 tom )
点击登出按钮,或进行重新登录的时候,会对先前登录时产生的信息进行销毁。
1 清空A应用的session和全局缓存中放置的tom的基本信息
2 向认证中心发出tom登出的通知。
3 认证中心接收到通知后,会把该通知通过hessian广播给所有子应用(利用子应用启动时向认证中心注册的信息来实现广播)。
4 接到通知的各个子应用会清空应用的全局缓存中放置的tom的基本信息。
因为“已经登录”的前提条件是 session中和应用的全局缓存中也有该用户的基本信息,
所以这时,在所有的子应用中,tom的状态都是为登出,这样做到了各个子应用间的同步。
对于登出的处理,和cas完全不同,cas是通过消灭cookie.
=====================================
访问流程:
(登录后,在各个子应用间切换的流程比较复杂,所以最后讲.)
假设tom已经通过A应用的入口 成功登录了A应用,并且认证中心正常工作。
此时访问B应用
1 判断tom是否已经登录了B应用
(通过判断B应用的session和全局缓存中是否有该用户的基本信息)
2 如果有 说明已经登录过(访问过)B应用,则进行正常访问。
3 如果没有,即tom没有登录过B应用,则尝试去认证中心 取用户的相关信息。
过程如下:
4 redirect到认证中心的指定url(同时发送当前用户请求的地址给认证中心),并从cookie中取ticket。
(cookie不能跨域,不redirect到认证中心是取不到ticket的)。
5 如果没有取到合法的ticket,则通知B应用跳转到登录页面(或出错页面)。
6 如果取到了ticket 则生成一个一次性的ticketKey,把ticket放入一个临时缓存,并返回B应用,同时把ticketKey返回给客户端。
7 B应用根据ticketKey从认证中心取用户名 密码.
过程如下:通过hessian 把 ticketKey 传递给认证中心,认证中心根据ticketKey去取ticket。
如果取到合法的ticket,则根据 ticket 通过hessian ,从认证中心的全局缓存中取得加密的 用户名 密码。
8 完成以上操作后 ,清除临时缓存中的ticketKey和ticket。
9 使用取得的用户名 密码,调用B应用的授权模块进行授权... 过程类似登录过程,但不需要认证中心重新产生ticket。
10 授权成功则 在B应用的session和全局缓存中放置用户基本信息,然后进行正常访问。
11 授权失败返回登录页面,并通知认证中心注销该ticket和用户基本信息(可以理解为,那个ticket失效了),
注销ticket时,认证中心会根据认证中心端的子应用列表,来通知各个子应用这个ticket失效了
各个子应用会从自己的全局缓存中清楚该ticket和其对应的用户基本信息(如果存在的话),过程类似登出过程。
=====================================
关于安全问题的一些探讨:
在这个系统中最需要保护的是用户名 密码 和 ticket。由于ticketKey具有瞬时性,被盗用的意义不大。
用户名 密码 和 ticket 始终通过 hessian传递,并且加密,即使被拦截,被盗用和破解的几率也极低.
ticketKey大多数情况下是通过hessian传递,但某应用第一次去认证中心取ticketKey时,
ticketKey是通过http的url传送的(这是不能避免的,即使强大的cas也是使用的这种方式,不同的是他使用了https,
其实,此处也是CAS坚持要使用HTTPS的一个主要原因)
减少"通过http协议,由URL传递ticket"的弊端的方式有三种:
1 使用HTTPS
2 使用一次性ticketKey
3 给ticketKey提供较短的失效时间
在这里我使用了 第2种方法。基本上可以避免ticketKey被盗用。
也许有人会想,如果可以生成一个和浏览器所在机器或用户IP绑定的ticketKey是不是可以解决这个问题,
即ticketKey被盗后,如果在其他机器使用,则无效。
这种思路看起来似乎可以,但其实不然。
原因很简单,web应用不能清晰准确的识别哪些访问来自同一台机器,从而可能导致合法的用户也无法对系统进行正常的访问。
http vs. https
单点登录系统中 保护用户名 密码 用户信息的唯一标识(ticket)是首要任务。
而坏人(在这里先这么称呼吧 因为我真的不想玷污黑客这个词)最想得到的就是这三者。
为了防止用户名 密码 ticket被盗,于是大多数sso系统采用了https。
在此处 https 比 http最主要最明显的优势就是传输的数据经过加密。
使得数据封包被拦截后,也几乎不可能从中破解出传输的数据。
但是,现在的坏人,主要的窃取用户信息的手段是什么?
在网内拦截封包,然后自己破解??错了,是用最简单的木马程序。
侵入用户的机器,直接记录键盘、拦截页面表单提交....
如果一个坏人,有能力侵入网络,来拦截各个机器之间的数据封包和http请求,那么他肯定也有能力直接在客户端的机器里做些手脚。
说的可能有些凌乱,重新总结一下吧:
如果想拥有可靠的安全性,要具备下面的几点:
1 整个网络系统 有完善的防火墙(使坏人不能随意的拦截网络数据封包)
2 认证中心、子应用所在机器要拥有完善的防火墙、完善的杀毒、防毒软件。
3 客户浏览器所在机器上,要有完善的防火墙、完善的杀毒、防毒软件。(这点最难保证)
4 机器之间的数据传输使用安全的传输协议(例如https)
以上4条,如果前3条得不到保证,那么安全性就无从谈起,第4条也就无足轻重了。
而如果前3条都满足了,那么第4条即使不满足,整个系统也同样安全,第4条同样无足轻重。
只有在 第2 3 条都满足,且第1条不满足的情况下,https才有用武之地。
所以,我的观点就是,对于"非公网"的单点认证系统,https不是必须的。
它在安全性方面起到的作用,和它带来的弊端想比,往往是弊大与利。
(其实,单点登录的系统,几乎都是企业内部的、非公网的系统)
注意:以上所言,都是针对传输的数据是 登录用户名 登录用户名 和 ticket的情况,如果传输是其他数据,则另当别论。
=====================================
目前已知不足:
1 不支持https协议。(虽然不是必须的,但毕竟很多时候还是需要用到https的,所以暂且算做一个不足吧)
2 不支持"同一用户在不同子应用中使用不同口令"的情况。
3 不支持同一台计算机上用多个账号同时登录。
4 和acegi结合的接口程序还没有编写完毕。
5 没有经历过绝对严格的测试。
6 整个系统完全没有任何的日志功能(我认为目前这不是必须的,而且我还不会用log4j common-logging这类组件)
7 认证中心端的管理模块还没有编写(同样,我认为目前这也不是必须的,完善基本功能是首要任务)
8 不支持类似CAS的业务代理模式。
9 不支持认证中心端的授权(本sso组件在设计的时候就没打算实现这个功能,呵呵)
10 虽然hessian支持多种语言,但是本sso组件没有提供非java的客户端版本。
=====================================
下一步工作:
1 完成与acegi的接口编码。
2 将 加密模块、唯一标识生成模块从主体中分离出来,可以通过配置来实现不同的加密、生成算法(类似acegi的做法)。
3 将 用户信息模型从主体中分离出来,做到更好的解藕,可以根据不同的需要配置不同的用户信息模型。(但核心仍然是Map来装载数据)
4 做一个稍微好点的S3OClient,但不会太好,因为计划将acegi作为client的主要承载者
5 提供从认证中心处统一登录(也就是提供统一的登录入口)。
6 支持认证中心端的统一授权。
7 认证中心端的简单的管理程序(查看认证中心中各种缓存中的数据)
还有个问题,你在cookie中设置超时的策略是什么呢?
这个好像没有看到你有提到。究竟设置多少时间才算合适呢?
如果用户一直在子系统A中操作,等到“若干长的时间”后才转向去登陆子系统B这个时候发现cookie已经过时了。那么用户不是又要重新登陆一次。这与单点登陆的意思好像又不符合了
各个子应用在启动的时候 向 认证中心注册了自己的信息
当用户退出的时候 把退出的消息发送给认证中心
认证中心利用自己得到的子应用的信息,向所有子应用发出 某某某 退出的消息
(实际上是调用 子应用发布的 hessian service)
这样各个子应用就也都知道 某某某退出了
不知道说明白没要是网络突然中断呢?用户退出的时候没有把退出的消息发送给认证中心呢?系统不是乱套了?
这种情况怎么处理?
利用一下session监听吧(服务器正常工作的情况下),在session被销毁的时候去做用户退出处理.session监听是一个办法
还有一个思路是直接在缓存上做文章
例如在ehcache
各个子应用在启动的时候 向 认证中心注册了自己的信息
当用户退出的时候 把退出的消息发送给认证中心
认证中心利用自己得到的子应用的信息,向所有子应用发出 某某某 退出的消息
(实际上是调用 子应用发布的 hessian service)
这样各个子应用就也都知道 某某某退出了
不知道说明白没要是网络突然中断呢?用户退出的时候没有把退出的消息发送给认证中心呢?系统不是乱套了?
这种情况怎么处理?
利用一下session监听吧(服务器正常工作的情况下),在session被销毁的时候去做用户退出处理.
由于刚涉及sso不久,对他还不是很了解(不了解也敢写组件? 呵呵 见笑了)
所以问题再所难免,系统大家能够给予指正和帮助,先谢谢了.
下面贴一下简单的说明文档, 里面不牵涉技术细节,只是我对它的一个简单的描述
看看设计上有什么地方需要改进没
在过几天,根据大家对它的建议和意见 做些改善后 再把代码和详细的使用配制方法贴上来.
(比较长 不好意思了)
==========================================
组件名称:S3O
一套轻量级的、简单易用的、高效的单点认证系统。
当然同样具有一定的安全性,也支持跨域。
S3O: Simple Single Sign-On ----> SSSOS
一个简简单单的单点认证组件,
既然 WWWC 叫做 W3C ,那自然SSSO也可以叫S3O了
=====================================
系统特性:
=====================================
1 基于http协议
2 支持跨域认证
3 各个子应用采用自己的登录入口,并且拥有独立的授权模块
4 支持子应用间的同步
5 重要信息加密后,通过hessian传递,并使用一次性ticketKey,安全性可以得到一定的保障。
6 绝对轻量级
7 基本原理应该(因为我没读过CAS的源代码,只看过一些相关文章,所以不敢肯定)类似CAS的基本模式(而不是它的代理模式).
( 当然要比CAS简单while(true){很多}了。 )
8 基于spring 和 hessian技术构建。缓存采用ehcache。
=====================================
术语解释:
=====================================
子应用:
就是需要提供单点登录的各个应用。
认证中心:
单点登录的认证中心。它也是个web应用。
可以把它理解为一个存放用户名和密码的公共空间,
各个子应用可以从它这里取用户名和密码,然后调用各自的授权模块对用户进行授权。
在该单点登录系统中,认证中心并不提供授权服务。
认证中心在客户端的cookie:
用于存放ticket的cookie。各个子应用的cookie不能在跨域的子应用之间共享,所以需要认证中心的cookie存放数据。
ticket:
认证中心生成的一个具有唯一性的标识,作为键,用来在认证中心缓存中保存登录用户的信息
同时ticket还将存放在认证中心在浏览器端的 cookie内
ticketKey:
认证中心生成的一个具有唯一性的标识,作为键,用来在认证中心缓存中保存ticket。
它是一次性的,当以ticketKey为键,从认证中心缓存中读取一次ticket后,该键将失效。
ticketKey会通过http在子应用与认证中心之间传递。
service:
通常指的是hessian service。
通过开源组件hessian发布的一种类似web service的远程服务。
serverMethod:
也是一种发布的远程服务,但调用方法是通过url调用。
可以理解为类似struts的dispatch action的实现。
(
就好像用下面的url访问dispatch action, 会自动执行action中的query方法一样
http://www.aaa.com/example.do?actionMethod=query
)
客户端浏览器、子应用、认证中心之间 就是通过各种service和serverMethod进行通讯的。
=====================================
单点登录主要流程概述:
=====================================
判断用户是否已经登录:
当前子应用的session中有用户的基本信息,同时当前子应用的全局缓存中也有该用户的基本信息。
则认为该用户已经在当前系统中登录。两个条件缺一不可。
==================================================
系统初始化流程:
1 启动认证中心(一个web应用)并进行相关的初始化(初始化filter、缓存、发布service等)
2 启动各个子应用(初始化filter、缓存、发布service等)
3 子应用通过hessian 向 认证中心 注册自己的信息(包括 子应用的url 子应用中发布的service等信息)
4 认证中心验证子应用是否有合法的key,没有合法的key,则不允许注册。
5 成功注册的子应用的信息会加入 认证中心的子应用信息列表内(一个全局缓存)
这个列表可以帮助认证中心向各个子应用来发广播,也可以用来在各个子应用间进行通讯和同步.
=====================================
登录流程
(假设登录A应用 登录的用户为 tom )
1 通过A应用的登录页面输入用户名tom 以及 密码
2 调用A应用的授权模块进行授权,授权失败返回登录页面。
3 授权成功,则将用户名 密码(加密后)通过hessian 发往 认证中心。
4 认证中心对其进行缓存,并产生ticket,将ticket和用户基本信息放入认证中心的缓存
5 同时还将生成ticketKey,以ticketKey做为键,把ticket放入认证中心端的一个临时的缓存内。
6 将ticketKey通过hessian返回给A应用。
7 A应用得到ticketKey后,通过内部redirect访问认证中心的指定url,该url用于产生cookiet
(该cookie为认证中心在客户端产生,cookiet内存放ticket)。
8 完成写cookie操作后 ,清楚临时缓存中的ticketKey和ticket。
9 以上步骤成功完成后,将在A应用session和全局缓存中放置用户的基本信息(用户名 ticket)。
此时,对于a应用来说,用户tom的状态为已登录.
=====================================
登出流程
(假设登出A应用,登出的用户为 tom )
点击登出按钮,或进行重新登录的时候,会对先前登录时产生的信息进行销毁。
1 清空A应用的session和全局缓存中放置的tom的基本信息
2 向认证中心发出tom登出的通知。
3 认证中心接收到通知后,会把该通知通过hessian广播给所有子应用(利用子应用启动时向认证中心注册的信息来实现广播)。
4 接到通知的各个子应用会清空应用的全局缓存中放置的tom的基本信息。
因为“已经登录”的前提条件是 session中和应用的全局缓存中也有该用户的基本信息,
所以这时,在所有的子应用中,tom的状态都是为登出,这样做到了各个子应用间的同步。
对于登出的处理,和cas完全不同,cas是通过消灭cookie.
=====================================
访问流程:
(登录后,在各个子应用间切换的流程比较复杂,所以最后讲.)
假设tom已经通过A应用的入口 成功登录了A应用,并且认证中心正常工作。
此时访问B应用
1 判断tom是否已经登录了B应用
(通过判断B应用的session和全局缓存中是否有该用户的基本信息)
2 如果有 说明已经登录过(访问过)B应用,则进行正常访问。
3 如果没有,即tom没有登录过B应用,则尝试去认证中心 取用户的相关信息。
过程如下:
4 redirect到认证中心的指定url(同时发送当前用户请求的地址给认证中心),并从cookie中取ticket。
(cookie不能跨域,不redirect到认证中心是取不到ticket的)。
5 如果没有取到合法的ticket,则通知B应用跳转到登录页面(或出错页面)。
6 如果取到了ticket 则生成一个一次性的ticketKey,把ticket放入一个临时缓存,并返回B应用,同时把ticketKey返回给客户端。
7 B应用根据ticketKey从认证中心取用户名 密码.
过程如下:通过hessian 把 ticketKey 传递给认证中心,认证中心根据ticketKey去取ticket。
如果取到合法的ticket,则根据 ticket 通过hessian ,从认证中心的全局缓存中取得加密的 用户名 密码。
8 完成以上操作后 ,清除临时缓存中的ticketKey和ticket。
9 使用取得的用户名 密码,调用B应用的授权模块进行授权... 过程类似登录过程,但不需要认证中心重新产生ticket。
10 授权成功则 在B应用的session和全局缓存中放置用户基本信息,然后进行正常访问。
11 授权失败返回登录页面,并通知认证中心注销该ticket和用户基本信息(可以理解为,那个ticket失效了),
注销ticket时,认证中心会根据认证中心端的子应用列表,来通知各个子应用这个ticket失效了
各个子应用会从自己的全局缓存中清楚该ticket和其对应的用户基本信息(如果存在的话),过程类似登出过程。
=====================================
关于安全问题的一些探讨:
在这个系统中最需要保护的是用户名 密码 和 ticket。由于ticketKey具有瞬时性,被盗用的意义不大。
用户名 密码 和 ticket 始终通过 hessian传递,并且加密,即使被拦截,被盗用和破解的几率也极低.
ticketKey大多数情况下是通过hessian传递,但某应用第一次去认证中心取ticketKey时,
ticketKey是通过http的url传送的(这是不能避免的,即使强大的cas也是使用的这种方式,不同的是他使用了https,
其实,此处也是CAS坚持要使用HTTPS的一个主要原因)
减少"通过http协议,由URL传递ticket"的弊端的方式有三种:
1 使用HTTPS
2 使用一次性ticketKey
3 给ticketKey提供较短的失效时间
在这里我使用了 第2种方法。基本上可以避免ticketKey被盗用。
也许有人会想,如果可以生成一个和浏览器所在机器或用户IP绑定的ticketKey是不是可以解决这个问题,
即ticketKey被盗后,如果在其他机器使用,则无效。
这种思路看起来似乎可以,但其实不然。
原因很简单,web应用不能清晰准确的识别哪些访问来自同一台机器,从而可能导致合法的用户也无法对系统进行正常的访问。
http vs. https
单点登录系统中 保护用户名 密码 用户信息的唯一标识(ticket)是首要任务。
而坏人(在这里先这么称呼吧 因为我真的不想玷污黑客这个词)最想得到的就是这三者。
为了防止用户名 密码 ticket被盗,于是大多数sso系统采用了https。
在此处 https 比 http最主要最明显的优势就是传输的数据经过加密。
使得数据封包被拦截后,也几乎不可能从中破解出传输的数据。
但是,现在的坏人,主要的窃取用户信息的手段是什么?
在网内拦截封包,然后自己破解??错了,是用最简单的木马程序。
侵入用户的机器,直接记录键盘、拦截页面表单提交....
如果一个坏人,有能力侵入网络,来拦截各个机器之间的数据封包和http请求,那么他肯定也有能力直接在客户端的机器里做些手脚。
说的可能有些凌乱,重新总结一下吧:
如果想拥有可靠的安全性,要具备下面的几点:
1 整个网络系统 有完善的防火墙(使坏人不能随意的拦截网络数据封包)
2 认证中心、子应用所在机器要拥有完善的防火墙、完善的杀毒、防毒软件。
3 客户浏览器所在机器上,要有完善的防火墙、完善的杀毒、防毒软件。(这点最难保证)
4 机器之间的数据传输使用安全的传输协议(例如https)
以上4条,如果前3条得不到保证,那么安全性就无从谈起,第4条也就无足轻重了。
而如果前3条都满足了,那么第4条即使不满足,整个系统也同样安全,第4条同样无足轻重。
只有在 第2 3 条都满足,且第1条不满足的情况下,https才有用武之地。
所以,我的观点就是,对于"非公网"的单点认证系统,https不是必须的。
它在安全性方面起到的作用,和它带来的弊端想比,往往是弊大与利。
(其实,单点登录的系统,几乎都是企业内部的、非公网的系统)
注意:以上所言,都是针对传输的数据是 登录用户名 登录用户名 和 ticket的情况,如果传输是其他数据,则另当别论。
=====================================
目前已知不足:
1 不支持https协议。(虽然不是必须的,但毕竟很多时候还是需要用到https的,所以暂且算做一个不足吧)
2 不支持"同一用户在不同子应用中使用不同口令"的情况。
3 不支持同一台计算机上用多个账号同时登录。
4 和acegi结合的接口程序还没有编写完毕。
5 没有经历过绝对严格的测试。
6 整个系统完全没有任何的日志功能(我认为目前这不是必须的,而且我还不会用log4j common-logging这类组件)
7 认证中心端的管理模块还没有编写(同样,我认为目前这也不是必须的,完善基本功能是首要任务)
8 不支持类似CAS的业务代理模式。
9 不支持认证中心端的授权(本sso组件在设计的时候就没打算实现这个功能,呵呵)
10 虽然hessian支持多种语言,但是本sso组件没有提供非java的客户端版本。
=====================================
下一步工作:
1 完成与acegi的接口编码。
2 将 加密模块、唯一标识生成模块从主体中分离出来,可以通过配置来实现不同的加密、生成算法(类似acegi的做法)。
3 将 用户信息模型从主体中分离出来,做到更好的解藕,可以根据不同的需要配置不同的用户信息模型。(但核心仍然是Map来装载数据)
4 做一个稍微好点的S3OClient,但不会太好,因为计划将acegi作为client的主要承载者
5 提供从认证中心处统一登录(也就是提供统一的登录入口)。
6 支持认证中心端的统一授权。
7 认证中心端的简单的管理程序(查看认证中心中各种缓存中的数据)
评论
29 楼
xiaokang1582830
2012-07-09
写得再多不如来一个demo容易理解...
28 楼
howesen
2007-09-17
楼主写的很不错的!只是有一些BUG可能还没有测试出来,建议再改进改进!给的例子运行时会出现一些打不开的界面URL,后面发现是认证服务器的URL中给不明不白地加了一个null在URL后,结果就错误了
27 楼
xmlspy
2007-03-30
看看这个http://xmlspy.iteye.com/admin/show/66745
能不能实现?
能不能实现?
26 楼
lordhong
2007-02-05
hessian和ehcache, 与spring没多大关系吧?
关注学习中...
关注学习中...
25 楼
magice
2007-02-05
fins 写道
那该怎么办呢?
不能只依赖session啊
我也在思考这个问题
我想如果全局缓存与seesion一定要放弃一个的话 我请愿放弃后者
首先谢谢你的回复。
不能只依赖session啊
我也在思考这个问题
我想如果全局缓存与seesion一定要放弃一个的话 我请愿放弃后者
还有个问题,你在cookie中设置超时的策略是什么呢?
这个好像没有看到你有提到。究竟设置多少时间才算合适呢?
如果用户一直在子系统A中操作,等到“若干长的时间”后才转向去登陆子系统B这个时候发现cookie已经过时了。那么用户不是又要重新登陆一次。这与单点登陆的意思好像又不符合了
24 楼
fins
2007-02-05
那该怎么办呢?
不能只依赖session啊
我也在思考这个问题
我想如果全局缓存与seesion一定要放弃一个的话 我请愿放弃后者
不能只依赖session啊
我也在思考这个问题
我想如果全局缓存与seesion一定要放弃一个的话 我请愿放弃后者
23 楼
magice
2007-02-05
你这个s3o判断用户时,一方面在子应用中判断session,一方面还在全局缓存中判断!
那么如何对一个稍微大一些的应用同时在线几万个人,那么全局缓存中必须存放几万条记录,这好像对效率来说不太好哦
那么如何对一个稍微大一些的应用同时在线几万个人,那么全局缓存中必须存放几万条记录,这好像对效率来说不太好哦
22 楼
fins
2007-02-02
确实 和spring绑定可能不太好
但是我觉得使用 hessian 和ehcache还是可以的
后两者更接近 工具类 而且绝对够轻.
如果你对第3方组件有抵触,我可以把他们的源代码 和 s3o直接打到一个jar包里 呵呵
其实我最近除了工作之外 一直在忙着ecside相关的开发
这个东西好久没弄了 等ecside可以有一个比较稳定的版本后 我会来好好弄一下这个小东西的.
因为我始终坚信 基于http协议的sso始终还是有用武之地的.
但是我觉得使用 hessian 和ehcache还是可以的
后两者更接近 工具类 而且绝对够轻.
如果你对第3方组件有抵触,我可以把他们的源代码 和 s3o直接打到一个jar包里 呵呵
其实我最近除了工作之外 一直在忙着ecside相关的开发
这个东西好久没弄了 等ecside可以有一个比较稳定的版本后 我会来好好弄一下这个小东西的.
因为我始终坚信 基于http协议的sso始终还是有用武之地的.
21 楼
minimu
2007-02-02
8 基于spring 和 hessian技术构建。缓存采用ehcache。
>>>>也许个人认为这是最大的败笔了
和框架绑定太紧对一个组件而言不是什么好事情;别用什么重复发明轮子的话;至少我认为这种框架的侵入性太多不好
>>>>也许个人认为这是最大的败笔了
和框架绑定太紧对一个组件而言不是什么好事情;别用什么重复发明轮子的话;至少我认为这种框架的侵入性太多不好
20 楼
fins
2007-01-16
ppeter 写道
china2wto 写道
fins 写道
叶子 写道
跨域的 ms的passport算一个
其他还真没见到什么。
不过不清楚退出时候 这个是怎么通知其他的也退出的。
查看,是存了cookies的。
其他还真没见到什么。
不过不清楚退出时候 这个是怎么通知其他的也退出的。
查看,是存了cookies的。
各个子应用在启动的时候 向 认证中心注册了自己的信息
当用户退出的时候 把退出的消息发送给认证中心
认证中心利用自己得到的子应用的信息,向所有子应用发出 某某某 退出的消息
(实际上是调用 子应用发布的 hessian service)
这样各个子应用就也都知道 某某某退出了
不知道说明白没
这种情况怎么处理?
利用一下session监听吧(服务器正常工作的情况下),在session被销毁的时候去做用户退出处理.
还有一个思路是直接在缓存上做文章
例如在ehcache
19 楼
ppeter
2007-01-16
china2wto 写道
fins 写道
叶子 写道
跨域的 ms的passport算一个
其他还真没见到什么。
不过不清楚退出时候 这个是怎么通知其他的也退出的。
查看,是存了cookies的。
其他还真没见到什么。
不过不清楚退出时候 这个是怎么通知其他的也退出的。
查看,是存了cookies的。
各个子应用在启动的时候 向 认证中心注册了自己的信息
当用户退出的时候 把退出的消息发送给认证中心
认证中心利用自己得到的子应用的信息,向所有子应用发出 某某某 退出的消息
(实际上是调用 子应用发布的 hessian service)
这样各个子应用就也都知道 某某某退出了
不知道说明白没
这种情况怎么处理?
利用一下session监听吧(服务器正常工作的情况下),在session被销毁的时候去做用户退出处理.
18 楼
h819
2007-01-15
楼主的工作,已经给新手很多思路了
别打击了,有打击的功夫,也写点东西贡献贡献
别打击了,有打击的功夫,也写点东西贡献贡献
17 楼
fins
2006-12-18
这个可以实现 找一个hession的php .net版就可以 因为核心是hession + http request
16 楼
ohlala
2006-12-17
这个应该只适合java应用。
如果client端是delphi vb c# 或 asp php .net 怎么和你写的这个S3O进行单点登录呢,有什么好的想法和解决方法么?
如果client端是delphi vb c# 或 asp php .net 怎么和你写的这个S3O进行单点登录呢,有什么好的想法和解决方法么?
15 楼
fins
2006-11-22
是的 呵呵
本来还想做的更好一点
但是现在出差在外 超级忙的说
很多想法都没有机会变成现实
:(
本来还想做的更好一点
但是现在出差在外 超级忙的说
很多想法都没有机会变成现实
:(
14 楼
fly_ever
2006-11-21
谢谢你的回复,因为这段时间也在看单点登录的相关内容,所以仔细看了这个方案。
根据你的回复,认证过程是在子应用中完成的,只是认证时需要到认证中心去取用户名和密码的信息,是这样的吧。
而在认证中心的ticket备份就是指每次登录完成后缓存的ticket信息吧。
根据你的回复,认证过程是在子应用中完成的,只是认证时需要到认证中心去取用户名和密码的信息,是这样的吧。
而在认证中心的ticket备份就是指每次登录完成后缓存的ticket信息吧。
13 楼
fins
2006-11-21
1 我们的系统比较特殊
确实向你说的
在A应用中进行认证,然后授权,成功后把登录信息发往认证中心保存起来
在这里 中心 只是负责存放 用户名和密码等基本信息
2 从cookie中取到的ticket是否在认证中心中有与之对应的ticket备份
确实向你说的
在A应用中进行认证,然后授权,成功后把登录信息发往认证中心保存起来
在这里 中心 只是负责存放 用户名和密码等基本信息
2 从cookie中取到的ticket是否在认证中心中有与之对应的ticket备份
12 楼
fly_ever
2006-11-20
有几个不理解的地方,还麻烦指教:
1,
认证中心:
单点登录的认证中心。它也是个web应用。
可以把它理解为一个存放用户名和密码的公共空间,
各个子应用可以从它这里取用户名和密码,然后调用各自的授权模块对用户进行授权。
在该单点登录系统中,认证中心并不提供授权服务。
我的理解为在认证中心对用户进行身份认证,然后在每个具体的子应用进行授权。
可是在登录流程中:
(假设登录A应用 登录的用户为 tom )
1 通过A应用的登录页面输入用户名tom 以及 密码
2 调用A应用的授权模块进行授权,授权失败返回登录页面。
3 授权成功,则将用户名 密码(加密后)通过hessian 发往 认证中心。
这里看起来是在A应用中进行认证,然后授权,成功后把登录信息发往认证中心保存起来。
2,在访问流程中,
4 redirect到认证中心的指定url(同时发送当前用户请求的地址给认证中心),并从cookie中取ticket。
(cookie不能跨域,不redirect到认证中心是取不到ticket的)。
5 如果没有取到合法的ticket,则通知B应用跳转到登录页面(或出错页面)。
怎么样判断取到的ticket是不是合法?
1,
引用
认证中心:
单点登录的认证中心。它也是个web应用。
可以把它理解为一个存放用户名和密码的公共空间,
各个子应用可以从它这里取用户名和密码,然后调用各自的授权模块对用户进行授权。
在该单点登录系统中,认证中心并不提供授权服务。
我的理解为在认证中心对用户进行身份认证,然后在每个具体的子应用进行授权。
可是在登录流程中:
引用
(假设登录A应用 登录的用户为 tom )
1 通过A应用的登录页面输入用户名tom 以及 密码
2 调用A应用的授权模块进行授权,授权失败返回登录页面。
3 授权成功,则将用户名 密码(加密后)通过hessian 发往 认证中心。
这里看起来是在A应用中进行认证,然后授权,成功后把登录信息发往认证中心保存起来。
2,在访问流程中,
引用
4 redirect到认证中心的指定url(同时发送当前用户请求的地址给认证中心),并从cookie中取ticket。
(cookie不能跨域,不redirect到认证中心是取不到ticket的)。
5 如果没有取到合法的ticket,则通知B应用跳转到登录页面(或出错页面)。
怎么样判断取到的ticket是不是合法?
11 楼
fins
2006-11-06
确实有超时机制
对于用户意外连接中断 只能靠超时来解决
在ehcache里设置的
但是具体时间我没有深思熟虑 只是随便的写了一个数字 呵呵
对于用户意外连接中断 只能靠超时来解决
在ehcache里设置的
但是具体时间我没有深思熟虑 只是随便的写了一个数字 呵呵
10 楼
Gene
2006-11-05
你的单点登录产品的支不支持数字证书,密码验证多层次的验证? 同时, 你的单点登录能否作为插件运行在apache,iis等常用的web server上?你的单点登录是否有安全策略管理方面的功能(设置哪些用户能访问那些url, 那些用户需要哪个层次的安全验证)?
建议参考一下 CA 的 eTrust® Single Sign-On。
建议参考一下 CA 的 eTrust® Single Sign-On。
发表评论
-
一个商业公司如果要支持一个开源项目的话,它需要做哪些工作啊?
2009-12-07 16:55 5044一个商业公司如果要支持一个开源项目的话,它需要做哪些工作呢? ... -
如何让jxl (jexcelapi) 支持更多的数据
2009-01-08 23:52 4527jxl (jexcelapi) 一直是我比较喜欢的 java版 ... -
在java中"模拟" XMLHttpRequest
2008-11-03 12:17 13131这里所说的"模拟" 是指 : 在java中 ... -
利用google docs进行"轻量级过程管理".
2008-08-28 13:21 0利用google docs进行" ... -
[请教]jxl生成xls时,支持"合并"或"磁盘缓存"吗(导出大数据量时)
2008-07-28 09:37 6973jxl 由于其小巧 易用的特点, 逐渐已经取代了 POI-ex ... -
不错的国产开源免费的php框架: FleaPHP
2008-07-28 01:58 8545之前用他开发过一个小的网站 开发过程非常轻松愉快 体验也很好 ... -
GT-FrontController, 一个简陋的MVC控制器的设计思路
2008-07-06 23:53 2740在给GT-Grid做前后台结合的例子时, 为了"快速 ... -
h2database 普及系列一: 简介
2008-05-06 19:10 22155这不是一个新东西,但是 ... -
JSF 与 "我的伟大发明" ---- 关于B/S UI开发的胡言乱语
2008-04-10 14:25 14576这篇帖子后面的回复和 ... -
初看JSF后的胡言乱语
2008-04-10 09:31 4590最近看了一点jsf ---- 只 ... -
Help,如何在J2EE环境下使用Sqlite以及如何将sqlite打入war包
2008-03-27 09:46 3815需求是这样的 希望j2ee应用(基于应用 而不是整个服务器) ... -
请记住: i AM SoLiD. (关于View的事件触发顺序)
2007-11-16 04:11 2649View 提供了若干事件. 在渲染 布局 展现 相关事件的触 ... -
Android SDK下, 如何在程序中输出日志 以及如何查看日志.
2007-11-15 22:38 9856Android SDK下, 如何在程序中输出日志 以及如何查看 ... -
小胖加入Android Fans的 大军了 呵呵
2007-11-15 13:30 3166决定开始研究 Android 了. 以前研究过 j2me 对 ... -
老帖: findbugs简介
2007-11-02 10:09 3572这个时候说 findbugs ??? ... -
世上没有B/S系统,只有B系统和S系统.
2007-09-12 13:45 34475先说些与标题貌似无关的话. 随着prototype DWR ... -
[求助]有没有哪个缓存组件支持 基于访问频率的清理策略
2007-08-29 18:30 2416目前缓存清理策略几乎都是基于 存活期 和 活跃期 还有缓存队列 ... -
[发布2007-08-06]Ajax向导组件 WebWizard Component Beta1
2007-08-06 15:55 5017/****************************** ... -
寻求一个eclipse下更好的snippet插件(或代码模板管理插件 或代码生成器)
2007-07-26 11:12 4272eclipse自带一个snippet插件,但是功能有限. 只支 ... -
让Struts 1焕发青春----小议对Struts的改造.
2007-06-25 15:27 7619目前流行的新型的MVC框架 几乎都在"增强单元测试能 ...
相关推荐
MINIO服务器是一款开源的对象存储系统,它模仿了亚马逊的S3云存储服务。在这个场景中,我们将探讨如何使用AWS S3 SDK(Software Development Kit)在C++中实现对MINIO服务器上的文件进行上传和下载。AWS S3 SDK为...
例如,`spark.read.format("csv").load("s3a://bucket-name/path/to/file.csv")`会读取S3上的CSV文件到一个Spark DataFrame。 6. **Hadoop读取S3**: 在Hadoop MapReduce或HDFS操作中,可以使用`FileSystem`类的`...
6. **存储配置**:S3C44B0通常需要一个Nor Flash来存储引导加载程序和操作系统,以及SDRAM来运行程序和存储数据。这些需要根据实际应用需求进行选择和配置。 7. **调试接口**:为了进行软件开发和故障排查,S3C44B0...
在这个例子中,我们创建了一个`S3Client`实例,设置了上传请求,包括桶名、对象键和本地文件,然后调用`PutObject`方法来执行实际的上传操作。如果操作成功,控制台会显示“File uploaded successfully.”;如果出现...
S3Connection是一个简单的连接类,用于将文件和数据上传到Amazon S3存储桶。 S3连接参考 完成处理程序 typedef void (^S3CompletionHandler)(NSError *) 上传成功完成或失败后,将调用完成处理程序。 NSError将在...
只需几个简单的命令行实用程序即可列出,复制和查看S3文件,例如s3cp , s3ls , s3cat , s3rm等。 正在安装 确保在系统上安装了Rubygems,然后运行: # gem install s3cp 例子 export AWS_ACCESS_KEY_ID=... ...
s3backer是一个文件系统,其中包含由 (Amazon S3) 支持的单个文件。 作为一个文件系统,它非常简单:它提供了一个固定大小的普通文件。 在下面,文件被分成块,每个块的内容存储在一个唯一的 Amazon S3 对象中。 ...
s3img - Amazon S3 图像处理和上传工具目的s3img是一个基于 Node.JS 的 CLI 工具。 其最初目的是使用 ImageMagick 转换和处理图像并将这些图像上传到 Amazon S3。 这背后的意图是为在线商店系统提供不同的图像结果...
总结来说,s3fs是一个方便开发人员和系统管理员在Linux环境中利用Amazon S3的工具,通过提供一个熟悉的文件系统接口,简化了云存储的使用。它通过FUSE实现用户空间的文件系统,降低了操作复杂性,但也需要注意其性能...
S3C2440系统时钟详解 S3C2440系统时钟是 ARM920T 内核的核心组件之一,对整个系统的稳定运行至关重要。...S3C2440 的时钟系统是一个复杂的系统,需要对时钟频率、PLL、寄存器和总线模式等有深入的了解和理解。
GitToS3 将文件部署到s3。注意: 如果文件名包含utf-8字符,请添加quotepath = false 到您的项目/.git/config 在[核心]部分要求: s3用法: 设置config.json(请参阅config.json.example)deploy.rb -v详细--dryrun ...
总结来说,ARM9_S3C2440最小系统是一个集成了ARM920T内核的嵌入式硬件平台,通过合理的硬件设计和软件开发,可以构建各种嵌入式应用,如工业控制、智能家居、移动设备等。提供的文档"ARM9_S3C2440最小系统.doc"应...
其内部包含了一个复杂的时钟管理系统,用于生成和管理各种工作频率。这个系统由多个振荡器、锁相环(PLL)、分频器等组成,可以根据系统需求提供不同频率的时钟源。例如,CPU时钟、总线时钟、外设时钟等都可以独立...
S3C4510B是Samsung公司推出的一款基于ARM7TDMI内核的微处理器,广泛应用于嵌入式系统设计中。 首先,我们来了解S3C4510B。它是一款高性能、低功耗的32位RISC(精简指令集计算机)微控制器,内含ARM7TDMI核心,支持...
毕设的时候做的一个简单的OS内核。ARM体系结构的,在s3c2440开发板上跑过。开发环境是RealView。...文件系统:模仿yaffs写的一个nand flash 文件系统,依然简单粗暴。 附上了设计文档与PPT。希望分享给愿意学习的人。
基于 nginx 的 s3 代理 - docker 从 S3 为您的静态主页提供服务,同时通过在 docker 中运行的 nginx 代理来保持存储桶的私密性。 用法 克隆这个 repo: git clone --recursive ...
Python_s3 是一个关于使用 Python 与 Amazon S3 进行交互的项目。S3,全称 Simple Storage Service,是亚马逊提供的一种云存储服务,它允许用户存储和检索大量数据,并具有高可用性和持久性。Python 作为一种广泛...
然而,随着日常使用,手机可能会遇到系统故障、病毒感染或者误操作导致的问题,这时就需要一个可靠的恢复系统来帮助用户恢复到正常状态。中兴U960S3中文恢复系统V1.0便是为此而生的工具,它专为这款设备提供系统备份...
s3fs 软件包s3fs为Go1.16接口提供了S3实现。 由于S3是平面结构,因此s3fs通过使用前缀和“ /” delim来模拟目录。 目录上的ModTime始终为零值。 该实现将包装为s3客户端。 const bucket = "my-bucket"s , err := ...