用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.client
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的注销页面,这个情况下,假设直接点击浏览器的回退button,发现仍然能够正常操作。也就是session并没有被注销掉,可能CAS的logout仅仅是去掉了TGT吧。
为了解决问题,我仅仅好又一次写了个JSP。退出button跳转到这个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>

说明:"/myweb"就是你退出后默认转到的界面, application.getInitParameter,须要自己在web.xml中增加context-parameter的配置. 这样才干成功跳转到你退出登录后想要跳转到的界面.


经过測试。能够实现所要的功能。

(二)SSO之CAS框架单点退出,自己定义退出界面.的更多相关文章

  1. (二)SSO之CAS框架单点退出,自定义退出界面.

    用CAS的退出,只能使用它自己的那个退出界面,如果有这样的要求, 要求退出后自动跳转到登录界面, 该如何做呢?下面这篇文章实现了退出后可以自定义跳转界面.  用了CAS,发现退出真是个麻烦事,退出后跳 ...

  2. (三)SSO之CAS框架单点退出,退出到CAS登录界面

    应需求的改变.CAS自定义登录页面不安全,不再使用,于是我一下子回到了原点,在linux上部署上了没有加自定义登陆界面的CAS,接下来开始修改CAS自己默认的登录界面为我们的界面. 一下子修改成功是根 ...

  3. (四)SSO之CAS框架单点登录,自定义验证登录方式

    应需求的变化,在登录cas的时候,默认根据用户名和密码进行验证,如果加上用户名,密码和一个系统标识进行验证呢?该如何做呢? 我们知道cas默认的登录界面中,输入的用户名和密码,再配置一下deploye ...

  4. (一)SSO之CAS框架通俗原理

    版权声明:本文为博主原创文章.转载请标明出处. https://blog.csdn.net/lovesummerforever/article/details/36068249 SSO统一验证     ...

  5. SSO 基于CAS实现单点登录 实例解析(二)

    本文目录: 概述 演示环境 部署CAS-Server相关的Tomcat 部署CAS-Client相关的Tomcat 测试验证SSO 第一: 本demo在一个机器上实现(三个虚拟主机),来看SSO单点登 ...

  6. (六)SSO之CAS框架扩展 改动CAS源代码实现与ESS动态password验证对接

    题记: 偶尔的偶尔我们会听到这个站点的数据泄露了,那个站点的用户数据泄露了.让用户又一次改动登录password,所以,对于用户数据安全性越发的引起我们的重视了,尤其是一些保密性要求高的站点.更须要添 ...

  7. CAS实现单点登录SSO执行原理及部署

    一.不落俗套的开始 1.背景介绍 单点登录:Single Sign On,简称SSO,SSO使得在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统. CAS框架:CAS(Centra ...

  8. SSO之CAS单点登录实例演示

    本文目录: 一.概述 二.演示环境 三.JDK安装配置 四.安全证书配置 五.部署CAS-Server相关的Tomcat 六.部署CAS-Client相关的Tomcat 七. 测试验证SSO 一.概述 ...

  9. CAS实现单点登录SSO执行原理探究超详细

    一.不落俗套的开始 1.背景介绍 单点登录:Single Sign On,简称SSO,SSO使得在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统. CAS框架:CAS(Centra ...

随机推荐

  1. WPF动画基础及实例

    1.介绍 在之前做winform中, 也做过一些动画效果, 但是整个动画都需要我们自己去编写, 利用计时器或线程去直接操作UI元素的属性, 然而在WPF中, 则是通过一种全新的基于属性的动画系统, 改 ...

  2. 洛谷 P2867 [USACO06NOV]大广场Big Square

    P2867 [USACO06NOV]大广场Big Square 题目描述 Farmer John's cows have entered into a competition with Farmer ...

  3. Android使用蓝牙连接adb调试App

    使用WiFi连接Android设备调试APP的教程非常多,可是项目中须要使用蓝牙进行通信.所以牵扯使用蓝牙调用adb. 1.   将电脑蓝牙与手机进行配对(控制面板->设备和打印机->加入 ...

  4. 20亿与20亿表关联优化方法(超级大表与超级大表join优化方法)

    记得5年前遇到一个SQL.就是一个简单的两表关联.SQL跑了几乎相同一天一夜,这两个表都非常巨大.每一个表都有几十个G.数据量每一个表有20多亿,表的字段也特别多. 相信大家也知道SQL慢在哪里了,单 ...

  5. php课程 12-40 抽象类的作用是什么

    php课程 12-40 抽象类的作用是什么 一.总结 一句话总结:定标准的 1.继承的关键词有哪两个? extendsparent 2.抽象类的实际意义是什么? 制造符合规范的产品你必须实现了抽象类里 ...

  6. 【编程】概念的理解 —— socket

    socket:A socket is something into which something is plugged or fitted (also called a receptacle). A ...

  7. if 的理解

    1. if 实现集合的划分 比如著名的 Prim 算法(最小生成树),从某一确定的点出发,每次新加入的点,都是在已访问过的结点(u∈U)和未访问过(v∈V−U)的结点之间的边.这里的未被访问(V−U) ...

  8. HDU4825 Xor Sum(贪心+Trie树)

    Problem Description Zeus 和 Prometheus 做了一个游戏,Prometheus 给 Zeus 一个集合,集合中包含了N个正整数,随后 Prometheus 将向 Zeu ...

  9. linux创建新用户并给予root权限

    root比windows的系统管理员的能力更大,足以把整个系统的大部分文件删掉,导致系统完全毁坏,不能再次使用.所以,用root进行不当的操作是相当危险的,轻微的可以死机,严重的甚至不能开机.所以,在 ...

  10. curl如何发起DELETE/PUT请求

    curl如何发起DELETE/PUT请求 DELETE: curl_setopt($ch, CURLOPT_CUSTOMREQUEST, 'DELETE'); PUT: curl_setopt($ch ...