CAS退出後跳轉到登陸頁面

用了CAS,發現退出真是個麻煩事,退出後跳轉到了CAS的註銷頁面,而且不關閉瀏覽器的話,其實並沒有真的退出,輸入地址仍是登陸狀態。爲了實現退出後登陸到跳轉頁面,做了以下配置:

1.server 端

修改src\main\webapp\WEB-INF\cas-servlet.xml裏的logoutController
增加p:followServiceRedirects="true"使支持logout輸入service參數爲跳轉路徑。

  1. <bean id="logoutController" class="org.jasig.cas.web.LogoutController"  
  2. p:centralAuthenticationService-ref="centralAuthenticationService"  
  3. p:logoutView="casLogoutView"  
  4. p:warnCookieGenerator-ref="warnCookieGenerator"  
  5. p:ticketGrantingTicketCookieGenerator-ref="ticketGrantingTicketCookieGenerator"   
  6. p:followServiceRedirects="true"  
  7. />  


2.客戶端
web.xml 中在登錄的filter之前增加

  1. <!-- 填寫退出的URL -->  
  2.   <context-param>  
  3.     <param-name>casServerLogoutUrl</param-name>  
  4.     <param-value>http://10.1.83.34:8080/cas/logout</param-value>  
  5.   </context-param>  
  6.    <!--單點退出配置-->  
  7.     <listener>  
  8.     <listener-class>org.jasig.cas.client.session.SingleSignOutHttpSessionListener</listener-class>  
  9. </listener>   
  10. <filter>  
  11.    <filter-name>CAS Single Sign Out Filter</filter-name>  
  12.    <filter-class>org.jasig.cas.client.session.SingleSignOutFilter</filter-class>  
  13. </filter>  
  14. <filter-mapping>  
  15.    <filter-name>CAS Single Sign Out Filter</filter-name>  
  16.    <url-pattern>/*</url-pattern>  
  17. </filter-mapping>  



在JSP中,如果直接把退出轉到cas/logout之後,會跳轉到CAS的註銷頁面,這個情況下,如果直接點擊瀏覽器的回退按鈕,發現仍然可以正常操作,也就是session並沒有被註銷掉,可能CAS的logout只是去掉了TGT吧。
爲了解決這個問題,我只好重新寫了個JSP,退出按鈕跳轉到這個JSP,這個JSP裏先註銷session, 然後再跳轉到CAS的退出,並增加service參數,使跳轉到登陸頁面。
  1. <a  
  2.     href="${pageContext.request.contextPath}/web-root/include/logout.jsp" ></a>  
  3. <div id="box_T5" class="toptaps5">退出登錄</div>  



logout.jsp內容:
  1. <body>  
  2. <%  
  3. session.invalidate();  
  4. response.sendRedirect(application  
  5. .getInitParameter("casServerLogoutUrl")  
  6. + "?service="  
  7. + application.getInitParameter("serverName") + "/myweb");  
  8. %>  
  9. </body>  



經過測試,可以實現所要的功能。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章