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

news/2024/6/2 22:21:26
用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>  
说明:"/myweb"就是你退出后默认转到的界面, application.getInitParameter,需要自己在web.xml中加入context-parameter的配置. 这样才能成功跳转到你退出登录后想要跳转到的界面.
 
经过测试,可以实现所要的功能。

http://www.niftyadmin.cn/n/3484060.html

相关文章

头条、快手,那些我曾经错过的暴富机会

本文首发于微信公共号&#xff1a; 中产之路 一位北京阿里的朋友M君到杭州出差&#xff0c;前几天一块吃饭&#xff0c;15-16年间&#xff0c;我们都在猎豹移动&#xff0c;是一个大组的同事兼饭友。聊了很多事情&#xff0c;一些共同认识的人和事&#xff0c;各自的行业动态等…

引入外部字体

在页面引入外部字体的方法style: 定义字体名字 font-face {font-family: MissYua;src: url("./css/fonts/MissYuan.woff") format(woff); } 类名引用 .environment { font-family: MissYua;font-size:64px;color:#005ead; } 标签复制代码标签<div class"env…

linux test

some test 1.在登录Linux时&#xff0c;一个具有唯一进程ID号的shell将被调用&#xff0c;这个ID是什么(b) A.NID B.PID C.UID C.CID2.下面那个用户存放用户密码信息(b) A./boot B./etc C./var D./dev3.用于自动补全功能时&#xff0c;输入命令或文件的前1个或后几个字母按什么…

使用RSA进行信息加密解密的WebService示例

按&#xff1a;以下文字涉及RSA对WebService传递的数据的加密解密&#xff0c;如果您已经熟知RSA或是有其它更好的方法请不要往下看以免浪费时间.WebService采用的协议是SOAP&#xff0c;它基于HTTP&#xff0c;而HTTP是明文方式&#xff0c;也就是说&#xff0c;采用WebServic…

Redis/------源码编译安装

1.下载解压 2.make 3 进入SRC ./redis-server 出现画面标识成功 4 下载 https://github.com/redis/hiredis/releases 5解压进入 make -j 6 make install转载于:https://www.cnblogs.com/Gupq/p/10540966.html

JavaScript中事件委托(事件代理)详解

在JavaScript的事件中,存在事件委托(事件代理),那么什么是事件委托呢? 事件委托在生活中的例子: 有三个同事预计会在周一收到快递。为签收快递&#xff0c;有两种办法&#xff1a;一是三个人在公司门口等快递&#xff1b;二是委托给前台MM代为签收。现实当中&#xff0c;我们大…

PostgreSQL逻辑备份恢复--pg_dump导出及psql导入案例

数据库导入导出是最常用的功能之一。PostgreSQL的备份工具可以使用pg_dump及pg_dumpall。可以通过pg_dump --help获取其使用方法。这里不对其做过多介绍。主要介绍在使用pg_dump及恢复过程中遇到的一个问题。 1、问题使用pg_dump -c导出后&#xff0c;通过psql导入时报下面的错…

分享一个基于ligerui的系统应用案例ligerRM V2(权限管理系统)(提供下载)

分享一个基于ligerui的系统应用案例ligerRM V2(权限管理系统)(提供下载)阅读目录 简介系统特色系统介绍 - 首页系统介绍 - 列表页系统介绍 - 明细页(表单)系统介绍 - 菜单/按钮系统介绍 - 权限中心系统介绍 - 数据权限系统介绍 - 字段权限系统介绍 - 下拉框应用细节结语简介 li…