CAS客户端退出登录

1. 直接访问 /cas/logout**(前端)**

最简单的方式是让前端浏览器重定向到 CAS 的登出 URL:

复制代码
window.location.href = "https://cas.example.org/cas/logout";

或通过超链接:

复制代码
<a href="https://cas.example.org/cas/logout">退出登录</a>
效果
  • CAS Server 会清除自身的会话(Session)。
  • 如果配置了 单点登出(SLO),CAS 会尝试通过回调或前端重定向通知所有已登录的客户端应用(需客户端支持)。

2. 带参数的登出(自定义回调)

CAS的 /cas/logout 支持以下参数:

  • service(可选):登出后重定向的 URL(需在 CAS 白名单中配置)。
  • url(可选):同 service(某些版本支持)。
示例
复制代码
window.location.href = "https://cas.example.org/cas/logout?service=https://your-app.com/logged-out";

或通过表单提交:

复制代码
<form action="https://cas.example.org/cas/logout" method="post">
  <input type="hidden" name="service" value="https://your-app.com/logged-out" />
  <button type="submit">退出登录</button>
</form>
注意
  • 客户端应用需在 CAS Server 的 服务管理(Service Management) 中配置允许的 service 回调地址。
  • 如果客户端需要清除本地会话,需在重定向到 service 的页面中处理(如删除 Cookie 或 Token)。

3. 后端调用 /cas/logout

CAS 的 /cas/logout 通常依赖浏览器重定向或回调通知客户端,直接通过后端 HTTP 请求调用无效(因为无浏览器上下文)。但可以通过以下方式间接实现:

方案
  1. 后端提供一个登出接口(如 /api/logout)。
  2. 接口内清除本地会话(如删除 Session/Token)。
  3. 返回重定向指令给前端,由前端跳转到 CAS 的 /cas/logout
示例(Spring Boot)
复制代码
@GetMapping("/logout")
public String logout(HttpServletRequest request, HttpServletResponse response) {
    // 1. 清除本地会话
    request.getSession().invalidate();
    
    // 2. 返回CAS登出URL(前端跳转)
    return "redirect:https://cas.example.org/cas/logout?service=https://your-app.com/logged-out";
}

总结调用流程

  1. 前端触发 :用户点击退出按钮 → 跳转到 https://cas.example.org/cas/logout?service=...
  2. CAS 处理:清除 CAS 会话 → 通知所有客户端(通过重定向或 Back-Channel)。
  3. 客户端处理 :在 service 回调页面或接口中清除本地会话。

实现全局同步登出

相关推荐
HoneyMoose14 小时前
Jenkins Cloudflare 部署提示错误
java·servlet·jenkins
阿丰资源14 小时前
基于SpringBoot的物流信息管理系统设计与实现(附资料)
java·spring boot·后端
Predestination王瀞潞14 小时前
Java EE3-我独自整合(第四章:Spring bean标签的常见配置)
java·spring·java-ee
overmind15 小时前
oeasy Python 121[专业选修]列表_多维列表运算_列表相加_列表相乘
java·windows·python
资深数据库专家15 小时前
总账EBS 应用服务器1 的监控分析
java·网络·数据库
房开民15 小时前
可变参数模板
java·开发语言·算法
t***54415 小时前
如何在现代C++中更有效地应用这些模式
java·开发语言·c++
_深海凉_15 小时前
LeetCode热题100-最小栈
java·数据结构·leetcode
不知名的忻15 小时前
Morris遍历(力扣第99题)
java·算法·leetcode·morris遍历
daidaidaiyu15 小时前
一文学习入门 ThingsBoard 开源物联网平台
java·mqtt·spring