2014-11-03 4 views
1

편집 질문이CAS 4, 제목과 같이 3.1.12

, 현재 내가 CAS 3.5.2를 사용하고, 그러므로 난 그냥 사용자를 변경 CAS의 4.i로 업그레이드 CAS 클라이언트 코어 제대로 작동하지 않습니다 casuser와 mellon의 이름을 admin으로 지정하십시오. 그것의 아주 최소한의 변화. I는, 예를 들면, 로그인 할 때 따라서 :

1 로그인, ABCD/로그인

2 성공 로그온 후에 CAS/로그인

3 리디렉션의 리디렉션/로그인 abcd와 세인트를 = XXXXXX 빈 페이지.

나는 일각에 그립니? 또는 pom.xml을 변경해야합니까? 아래

제의 pom.xml

<dependency> 
      <groupId>org.springframework.security</groupId> 
      <artifactId>spring-security-cas</artifactId> 
      <version>3.1.0.RELEASE</version> 
      <scope>compile</scope> 
     </dependency> 
     <dependency> 
      <groupId>org.opensaml</groupId> 
      <artifactId>opensaml</artifactId> 
      <version>1.1</version> 
      <scope>runtime</scope> 
     </dependency> 
     <dependency> 
      <groupId>xml-security</groupId> 
      <artifactId>xmlsec</artifactId> 
      <version>1.3.0</version> 
      <scope>runtime</scope> 
     </dependency> 
     <dependency> 
      <groupId>net.sf.ehcache</groupId> 
      <artifactId>ehcache</artifactId> 
      <version>1.6.2</version> 
      <scope>runtime</scope> 
     </dependency> 

내 에러 로그

java.lang.StringIndexOutOfBoundsException: String index out of range: -1 
    at java.lang.String.substring(String.java:1911) 
    at org.jasig.cas.client.validation.Saml11TicketValidator.parseResponseFromServer(Saml11TicketValidator.java:50) 
    at org.jasig.cas.client.validation.AbstractUrlBasedTicketValidator.validate(AbstractUrlBasedTicketValidator.java:197) 
    at org.springframework.security.cas.authentication.CasAuthenticationProvider.authenticateNow(CasAuthenticationProvider.java:140) 
    at org.springframework.security.cas.authentication.CasAuthenticationProvider.authenticate(CasAuthenticationProvider.java:126) 
    at org.springframework.security.authentication.ProviderManager.authenticate(ProviderManager.java:156) 
    at org.springframework.security.cas.web.CasAuthenticationFilter.attemptAuthentication(CasAuthenticationFilter.java:242) 
    at org.springframework.security.web.authentication.AbstractAuthenticationProcessingFilter.doFilter(AbstractAuthenticationProcessingFilter.java:194) 
    at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:323) 
    at org.springframework.security.web.authentication.logout.LogoutFilter.doFilter(LogoutFilter.java:105) 
    at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:323) 
    at org.jasig.cas.client.session.SingleSignOutFilter.doFilter(SingleSignOutFilter.java:65) 
    at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:323) 
    at org.springframework.security.web.context.SecurityContextPersistenceFilter.doFilter(SecurityContextPersistenceFilter.java:87) 
    at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:323) 
    at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:173) 
    at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346) 
    at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:259) 
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243) 
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 
    at sg.com.innovax.opscentralv5.objects.setEncoding.doFilter(setEncoding.java:100) 
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243) 
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:222) 
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:123) 
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472) 
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:171) 
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:99) 
    at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:947) 
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118) 
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:408) 
    at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1009) 
    at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:589) 
    at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:312) 
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145) 
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615) 
    at java.lang.Thread.run(Thread.java:722) 

따라서 나 오류 코드보기 체크 소스 코드 (패키지 org.jasig.cas 브레이크 포인트의 일부이다. client.validation;). Saml11TicketValidator.parseResponseFromServer에서, 응답 결과가 기대에 미치지 못했기 때문에 하위 문자열에 문제가 발생했습니다. 이 1 그냥 예외 처리, 근본적인 원인이되지 않습니다. 근본 원인은 Saml11TicketValidator retrieveResponseFromServer에 있습니다. 왜 CAS4 로그인 페이지를 반환합니까 (제 CAS4에서 이미 로그인 했습니까?) ??? 그게 버그 야?

참고 : 경우에 내 받는다는 종속성 CAS 클라이언트 코어-3.1.12.jar

답변

0

를 사용하는 대부분의 아마 u는 설정 SAML 1 일 필요 의미 Saml11TicketValidator에 cas4 반환 로그인 페이지.