2013-07-24 87 views
0

我在Apache Tomcat上安裝了CAS服務器(v3.5.2),在JBOSS上安裝了2個客戶端。 一切工作正常,除非單一登出。CAS單一註銷不起作用

我覺得我所做的都很好,但仍然存在這個問題。

我的配置服務器端: 在WEB-INF \ deployerConfigContext.xml裏:

<bean class="org.jasig.cas.services.RegexRegisteredService"> 
    <property name="id" value="1" /> 
    <property name="name" value="HTTP and IMAP on localhost:8080/firstCasClient" /> 
    <property name="description" value="Allows HTTP(S) and IMAP(S) protocols on localhost:8080/firstCasClient" /> 
    <property name="serviceId" value="^(https?|imaps?)://([A-Za-z0-9_-]+\.)*localhost:8080/firstCasClient/*" /> 
    <property name="ssoEnabled" value="true" /> 
    <property name="enabled" value="true" /> 
    <property name="evaluationOrder" value="0" /> 
</bean> 

<bean class="org.jasig.cas.services.RegexRegisteredService"> 
    <property name="id" value="2" /> 
    <property name="name" value="HTTP and IMAP on localhost:8080/secondCasClient" /> 
    <property name="description" value="Allows HTTP(S) and IMAP(S) protocols on localhost:8080/secondCasClient" /> 
    <property name="serviceId" value="^(https?|imaps?)://([A-Za-z0-9_-]+\.)*localhost:8080/secondCasClient/*" /> 
    <property name="ssoEnabled" value="true" /> 
    <property name="enabled" value="true" /> 
    <property name="evaluationOrder" value="1" /> 
</bean> 

配置在客戶端: 在web.xml:

<!-- CAS SINGLE SIGN OUT --> 
<filter> 
    <filter-name>CAS Single Sign Out Filter</filter-name> 
    <filter-class>org.jasig.cas.client.session.SingleSignOutFilter</filter-class> 
    <init-param> 
    <!-- because of use of Saml11TicketValidationFilter --> 
     <param-name>artifactParameterName</param-name> 
     <param-value>SAMLart</param-value> 
    </init-param> 
</filter> 
<filter-mapping> 
    <filter-name>CAS Single Sign Out Filter</filter-name> 
    <url-pattern>/*</url-pattern> 
    <dispatcher>REQUEST</dispatcher> 
    <dispatcher>FORWARD</dispatcher> 
</filter-mapping> 
<listener> 
    <listener-class>org.jasig.cas.client.session.SingleSignOutHttpSessionListener</listener-class> 
</listener> 

<!-- other filters --> 
<filter> 
    <filter-name>CAS Authentication Filter</filter-name> 
    <filter-class>org.jasig.cas.client.authentication.AuthenticationFilter</filter-class> 
    <init-param> 
     <param-name>casServerLoginUrl</param-name> 
     <param-value>http://localhost:8888/cas-server-webapp-3.5.2/login</param-value> 
    </init-param> 
    <init-param> 
     <param-name>service</param-name> 
     <param-value>http://localhost:8080/firstCasClient</param-value> 
    </init-param> 
</filter> 
<filter> 
    <filter-name>CAS Validation Filter</filter-name> 
    <filter-class>org.jasig.cas.client.validation.Saml11TicketValidationFilter</filter-class> 
    <init-param> 
     <param-name>casServerUrlPrefix</param-name> 
     <param-value>http://localhost:8888/cas-server-webapp-3.5.2</param-value> 
    </init-param> 
    <init-param> 
     <param-name>service</param-name> 
     <param-value>http://localhost:8080/firstCasClient</param-value> 
    </init-param> 
</filter> 
<filter> 
    <filter-name>CAS HttpServletRequest Wrapper Filter</filter-name> 
    <filter-class>org.jasig.cas.client.util.HttpServletRequestWrapperFilter</filter-class> 
</filter> 
<filter> 
    <filter-name>CAS Assertion Thread Local Filter</filter-name> 
    <filter-class>org.jasig.cas.client.util.AssertionThreadLocalFilter</filter-class> 
</filter> 
<filter-mapping> 
    <filter-name>CAS Authentication Filter</filter-name> 
    <url-pattern>/*</url-pattern> 
    <dispatcher>REQUEST</dispatcher> 
    <dispatcher>FORWARD</dispatcher> 
</filter-mapping> 
<filter-mapping> 
    <filter-name>CAS HttpServletRequest Wrapper Filter</filter-name> 
    <url-pattern>/*</url-pattern> 
    <dispatcher>REQUEST</dispatcher> 
    <dispatcher>FORWARD</dispatcher> 
</filter-mapping> 
<filter-mapping> 
    <filter-name>CAS Validation Filter</filter-name> 
    <url-pattern>/*</url-pattern> 
    <dispatcher>REQUEST</dispatcher> 
    <dispatcher>FORWARD</dispatcher> 
</filter-mapping> 
<filter-mapping> 
    <filter-name>CAS Assertion Thread Local Filter</filter-name> 
    <url-pattern>/*</url-pattern> 
    <dispatcher>REQUEST</dispatcher> 
    <dispatcher>FORWARD</dispatcher> 
</filter-mapping> 

我希望有人會發現什麼是錯誤的 謝謝

回答

1

請確保在您的argumentExtractorsConfiguration.xml文件中指出了cas ArgumentExtractor bean的disableSingleSignOut屬性設置爲false。如果你看到以下內容:

<bean id="casArgumentExtractor" 
     class="org.jasig.cas.web.support.CasArgumentExtractor" 
     p:httpClient-ref="noRedirectHttpClient" 
     p:disableSingleSignOut="${slo.callbacks.disabled:false}" /> 

拿你cas.properties一看,並確保slo.callbacks.disabled未設置爲true。 ${slo.callbacks.disabled:false}表示查找該屬性,如果找不到,則默認爲false。