(二)SSO之CAS框架单点退出,自己定义退出界面.
2024-08-31 19:12:52
用CAS的退出,仅仅能使用它自己的那个退出界面,假设有这种要求, 要求退出后自己主动跳转到登录界面, 该怎样做呢?
以下这篇文章实现了退出后能够自己定义跳转界面.
用了CAS,发现退出真是个麻烦事,退出后跳转到了CAS的注销页面,并且不关闭浏览器的话。事实上并没有真的退出。输入地址仍是登陆状态。
为了实现退出后登陆到跳转页面,做了下面配置:
1.server 端
改动src\main\webapp\WEB-INF\cas-servlet.xml里的logoutController
添加p:followServiceRedirects="true"使支持logout输入service參数为跳转路径。
- <bean id="logoutController" class="org.jasig.cas.web.LogoutController"
- p:centralAuthenticationService-ref="centralAuthenticationService"
- p:logoutView="casLogoutView"
- p:warnCookieGenerator-ref="warnCookieGenerator"
- p:ticketGrantingTicketCookieGenerator-ref="ticketGrantingTicketCookieGenerator"
- p:followServiceRedirects="true"
- />
2.client
web.xml 中在登录的filter之前添加
- <!-- 填写退出的URL -->
- <context-param>
- <param-name>casServerLogoutUrl</param-name>
- <param-value>http://10.1.83.34:8080/cas/logout</param-value>
- </context-param>
- <!--单点退出配置-->
- <listener>
- <listener-class>org.jasig.cas.client.session.SingleSignOutHttpSessionListener</listener-class>
- </listener>
- <filter>
- <filter-name>CAS Single Sign Out Filter</filter-name>
- <filter-class>org.jasig.cas.client.session.SingleSignOutFilter</filter-class>
- </filter>
- <filter-mapping>
- <filter-name>CAS Single Sign Out Filter</filter-name>
- <url-pattern>/*</url-pattern>
- </filter-mapping>
在JSP中,假设直接把退出转到cas/logout之后,会跳转到CAS的注销页面,这个情况下,假设直接点击浏览器的回退button,发现仍然能够正常操作。也就是session并没有被注销掉,可能CAS的logout仅仅是去掉了TGT吧。
为了解决问题,我仅仅好又一次写了个JSP。退出button跳转到这个JSP,这个JSP里先注销session, 然后再跳转到CAS的退出。并添加service參数。使跳转到登陆页面。
- <a
- href="${pageContext.request.contextPath}/web-root/include/logout.jsp" ></a>
- <div id="box_T5" class="toptaps5">退出登录</div>
logout.jsp内容:
- <body>
- <%
- session.invalidate();
- response.sendRedirect(application
- .getInitParameter("casServerLogoutUrl")
- + "?service="
- + application.getInitParameter("serverName") + "/myweb");
- %>
- </body>
说明:"/myweb"就是你退出后默认转到的界面, application.getInitParameter,须要自己在web.xml中增加context-parameter的配置. 这样才干成功跳转到你退出登录后想要跳转到的界面.
经过測试。能够实现所要的功能。
最新文章
- Docker和Docker-compose安装教程以及docker-elk,docker-storm安装教程
- 关于近期项目代码整理(iOS)
- 01HTTP服务&;AJAX编程
- mysql 行变列(多行变成一行/多行合并成一行/多行合并成多列/合并行)
- Spring MVC学习笔记——JSR303介绍及最佳实践
- 【SQL 触发器】
- EFS加密解密----重装系统后
- angular的directive笔记
- R语言分析(二)——薛毅R语言第二章后面习题解析
- 你真的会websocket吗
- 安装es6编译babel
- Android jni Crash堆栈信息分析
- Cpp Generals 1.2
- python搭建web服务
- 【最新】Android使用jenkins全自动构建打包-Windows版本(Android,Jenkins,360加固,Email,QRcode,参数构建,蒲公英)
- 网络之NSURLConnection
- ASP.NET获取服务器信息大全
- luogu P1401 城市
- MyEclipse使用总结——MyEclipse中配置WebLogic12c服务器
- 所有依赖的jar将提取到lib目录
热门文章
- SNMP介绍,OID及MIB库
- 史上最简单,js并获取手机型号
- [NOI.AC#30]candy 贪心
- 百度地图API 添加标签
- 1、DOM4J简介
- 一个虐你千百遍的问题:“RPC好,还是RESTful好?”
- hdu-3642--Get The Treasury-线段树求面积并
- 看好腾讯,鄙视百度(腾讯的核心竞争力,不是超过10亿的QQ的注册用户,也不是某一项产品、技术方面优势,而是“耐心”:懂得在合适的时间推出合适的产品。”)
- Redis原理(二)
- C++中引用传递与指针传递区别