国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > Java > 正文

Spring Security整合CAS的示例代碼

2024-07-14 08:41:28
字體:
來源:轉載
供稿:網友

這里使用的是spring-security和原生的jasig cas包來進行整合,為什么沒有直接使用spring提供的spring-security-cas,后面會進行解釋。

配置

web.xml

<filter> <filter-name>casFilterChain</filter-name> <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class></filter><filter-mapping> <filter-name>casFilterChain</filter-name> <url-pattern>/*</url-pattern></filter-mapping><listener> <listener-class>org.jasig.cas.client.session.SingleSignOutHttpSessionListener</listener-class></listener>

applicationContext-security.xml

<?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.springframework.org/schema/beans"  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  xmlns:security="http://www.springframework.org/schema/security"  xmlns:util="http://www.springframework.org/schema/util"  xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd  http://www.springframework.org/schema/security  http://www.springframework.org/schema/security/spring-security-3.2.xsd http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util.xsd"> <bean id="casFilterChain" class="org.springframework.security.web.FilterChainProxy">  <constructor-arg>   <util:list>    <security:filter-chain pattern="/**" filters="singleSignOutFilter, cas20ProxyReceivingTicketValidationFilter, authenticationFilter, httpServletRequestWrapperFilter, assertionThreadLocalFilter"/>   </util:list>  </constructor-arg> </bean> <bean id="singleSignOutFilter" class="org.jasig.cas.client.session.SingleSignOutFilter"/> <bean id="cas20ProxyReceivingTicketValidationFilter"   class="org.jasig.cas.client.validation.Cas20ProxyReceivingTicketValidationFilter">  <property name="serverName" value="${client.url}"/>  <property name="ticketValidator" ref="cas20ServiceTicketValidator"/> </bean> <bean id="cas20ServiceTicketValidator" class="org.jasig.cas.client.validation.Cas20ServiceTicketValidator">  <constructor-arg value="${cas.url}"/>  <property name="renew" value="false"/> </bean> <bean id="authenticationFilter" class="org.jasig.cas.client.authentication.AuthenticationFilter">  <property name="renew" value="false"/>  <property name="casServerLoginUrl" value="${cas.url}"/>  <property name="serverName" value="${client.url}"/> </bean> <bean id="httpServletRequestWrapperFilter" class="org.jasig.cas.client.util.HttpServletRequestWrapperFilter"/> <bean id="assertionThreadLocalFilter" class="org.jasig.cas.client.util.AssertionThreadLocalFilter"/></beans>

properties

#CAS服務地址cas.url=https://cas.example.com:8443#CAS客戶端地址,就是本應用的地址client.url=http://localhost:8080

分析

在applicationContext-security.xml中的security filter chain中,我們使用了5個filter,分別是:singleSignOutFilter、cas20ProxyReceivingTicketValidationFilter、authenticationFilter、httpServletRequestWrapperFilter、assertionThreadLocalFilter。

為什么不用spring-security-cas

spring-security-cas

在spring-security-cas中負責ticket validator filter使用的是org.springframework.security.cas.authentication.CasAuthenticationProvider。

private CasAuthenticationToken authenticateNow(final Authentication authentication) throws AuthenticationException { try {  final Assertion assertion = this.ticketValidator.validate(authentication.getCredentials().toString(), getServiceUrl(authentication));  ...

在構建validator的validator方法的第二個參數時

private String getServiceUrl(Authentication authentication) { String serviceUrl; if(authentication.getDetails() instanceof ServiceAuthenticationDetails) {  serviceUrl = ((ServiceAuthenticationDetails)authentication.getDetails()).getServiceUrl(); }else if(serviceProperties == null){  throw new IllegalStateException("serviceProperties cannot be null unless Authentication.getDetails() implements ServiceAuthenticationDetails."); }else if(serviceProperties.getService() == null){  throw new IllegalStateException("serviceProperties.getService() cannot be null unless Authentication.getDetails() implements ServiceAuthenticationDetails."); }else {  serviceUrl = serviceProperties.getService(); } if(logger.isDebugEnabled()) {  logger.debug("serviceUrl = "+serviceUrl); } return serviceUrl;}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 思南县| 昌乐县| 进贤县| 宣威市| 靖江市| 巴彦县| 义乌市| 磐安县| 陆丰市| 恭城| 新沂市| 札达县| 伊宁市| 丹棱县| 安龙县| 屏东市| 苏尼特右旗| 剑河县| 兴义市| 新密市| 同仁县| 淅川县| 无棣县| 宿州市| 富蕴县| 班戈县| 德州市| 大洼县| 大英县| 旅游| 鹤山市| 大姚县| 专栏| 集贤县| 陵川县| 方正县| 荥阳市| 腾冲县| 南陵县| 旌德县| 梁平县|