4000-520-616
欢迎来到免疫在线!(蚂蚁淘生物旗下平台)  请登录 |  免费注册 |  询价篮
主营:原厂直采,平行进口,授权代理(蚂蚁淘为您服务)
咨询热线电话
4000-520-616
当前位置: 首页 > 新闻动态 >
热卖商品
新闻详情
acegi整合CAS
来自 : 个人图书馆 发布时间:2021-03-25
acegi内置了对CAS的支持。这里的CAS是3.0。建立CAS server是一个比较简单的事情。CAS server就是一个标准的war文件,把它发布就可以运行。需要做的仅仅是调整登陆和其他一些页面。先了解一下CAS如何实现SSO。
例子:原有系统A和系统B,现在在它们之间做SSO。
很显然,系统A和B都是CASclient。首先是访问系统A,干掉A的登陆页面,在A的入口判断有没有Ticket(票据),如果没有则重定向到CAS server,在CASserver提供Credential(大多数情况就是用户名和密码)。CASserver的作用非常简单:就是来验证用户密码。正确,则发送Ticket。CAS有5种Ticket,分别是TGC(通过cookie发送的ticket),ST(ServiceTicket),PGT,PGTIOU,PT。其中PGT,PGTIOU,PT属于代理ticket,这里不作讨论。具体可以参考
http://www.blogjava.net/openssl/archive/2006/04/26/SSO_CASProxy.html
TGC和ST的关系可以打个比方:
我去中央电视塔去玩,结果发现地下还有个海底世界。SSO前我是这么玩的:先去电视塔买张门票,玩完了;再去海底世界买张门票,玩完了。发现真累,两个景点这么近还要买两次门票,就不能搞个通票吗?于是就SSO。于是这样:我先去电视塔,门卫告诉我你不能进去要买票,于是把我送到通票售票处(CASserver)买票(登录),买吧,于是给了我两张票,注意,是两张,一张发到我手里,上面写着仅限电视塔使用(ST);靠,不是通票吗,咋仅限电视塔使用?别急,还有一张票(TGC)通过cookie发送你看不见。人家说了保证没问题,我咋办,这是人家的规矩,那就先去玩吧。出了电视塔我直扑海底世界,
门卫说要海底世界票,不会吧,我买的通票啊,门卫说不着急,又把我送回通票售票处(CAS server),通票售票处(CASserver)一看,发现我有TGC,嘿嘿,这家伙买过票了不用再买(不用再登录),于是换我一张票(ST)上面写着仅限海底世界使用,于是我就拿着这张票又去海底世界了。于是我明白了啥是SSO了,不就是把买票改成换票了吗?
比方完了,最开始的例子也就不往下继续了。需要注意的是系统A和B整合SSO需要把A、B的用户密码集中管理,你说A中我的用户名是张三,B中是李四,SSO能不能帮我自动识别,回答是不行的。
继续Acegi的整合。
CASserver是做用户密码验证,具体的权限授权的工作还是在各个单个系统里,也不应该交给它管。做用户密码验证需要AuthenticationHandler。这个具体就是根据Credential返回一个boolean值来判断你输入的用户密码正不正确。acegi提供了一个实现。
以一个典型的web访问来说明整个过程
1、用户访问一个受acegi安全保护的页面或业务方法;
2、用户没有登陆的话显然会抛出AuthenticationException
3、配置exceptionTranslationFilter捕获这个异常重定向到CAS server登陆页面
beanid=\"exceptionTranslationFilter\"
propertyname=\"authenticationEntryPoint\" reflocal=\"casProcessingFilterEntryPoint\"/ /property
/bean

beanid=\"casProcessingFilterEntryPoint\"
propertyname=\"loginUrl\" value https://my.company.com/cas/login /value /property
propertyname=\"serviceProperties\" reflocal=\"serviceProperties\"/ /property
/bean

beanid=\"serviceProperties\"
propertyname=\"service\" value https://server.company.com/myapp/j_acegi_cas_security_check /value /property
propertyname=\"sendRenew\" value false /value /property
/bean serviceProperties里的service属性即在CAS server登陆完毕后由CAS server重定向回来的页面
https://my.company.com/cas/login?service=https%3A%2F%2Fserver.company.com%2Fmyapp%2Fj_acegi_cas_security_check
4、CAS server检查是否有TGC ,没有则登陆,登陆后返回。这里屁股后面跟着的即ST,TGC通过cookie一并发送到客户端。
https://server.company.com/myapp/j_acegi_cas_security_check?ticket=ST-0-jhsdfguwgeds
5、配置casProcessingFilter来处理返回ST(和以前的authenticationProcessingFilter比较类似)
beanid=\"casProcessingFilter\"
propertyname=\"authenticationManager\" reflocal=\"authenticationManager\"/ /property
propertyname=\"authenticationFailureUrl\" value /casfailed.jsp /value /property
propertyname=\"defaultTargetUrl\" value / /value /property
propertyname=\"filterProcessesUrl\" value /j_acegi_cas_security_check /value /property
/bean 6、配置authenticationManager
beanid=\"authenticationManager\"
propertyname=\"providers\"
list
reflocal=\"casAuthenticationProvider\"/
/list
/property
/bean

beanid=\"casAuthenticationProvider\"
propertyname=\"casAuthoritiesPopulator\" reflocal=\"casAuthoritiesPopulator\"/ /property
propertyname=\"casProxyDecider\" reflocal=\"casProxyDecider\"/ /property
propertyname=\"ticketValidator\" reflocal=\"casProxyTicketValidator\"/ /property
propertyname=\"statelessTicketCache\" reflocal=\"statelessTicketCache\"/ /property
propertyname=\"key\" value my_password_for_this_auth_provider_only /value /property
/bean 具体作用的是casAuthenticationProvider,casAuthenticationProvider通过 casProxyTicketValidator来校验ST
beanid=\"casProxyTicketValidator\"
propertyname=\"casValidate\" value https://my.company.com/cas/proxyValidate /value /property
propertyname=\"serviceProperties\" reflocal=\"serviceProperties\"/ /property
/bean casProxyTicketValidator又具体实现调用了CAS Clientlibrary里的ProxyTicketValidator校验ST,ProxyTicketValidator就比较有意思了,它做了个HTTPS请求CAS server,结果还是CAS server来校验ST(绕了一大圈)
https://my.company.com/cas/proxyValidate?service=https%3A%2F%2Fserver.company.com%2Fmyapp%2Fj_acegi_cas_security_check
重新回到CAS server,它接受到这个HTTPS请求,检查ST是否与对这个service发行的ST吻合,吻合的话CASserver就会发回一个肯定的XML回复,里面包含了用户名(username)。剩下的就EASY了,casProxyTicketValidator解析XML,casProxyDecider处理代理,casAuthoritiesPopulator根据解析后的XML获得user,最后就是casAuthenticationProvider构造Authentication(这里是CasAuthenticationToken)
7、重新回到casProcessingFilter,它将Authentication放入HttpSession
这样就完成了整个过程

本文链接: http://acegi0.immuno-online.com/view-724517.html

发布于 : 2021-03-25 阅读(0)
公司介绍
品牌分类
联络我们
服务热线:4000-520-616
(限工作日9:00-18:00)
QQ :1570468124
手机:18915418616