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 回调页面或接口中清除本地会话。

实现全局同步登出

相关推荐
代码羊羊20 小时前
Rust 迭代器完全通俗易懂指南(零基础全覆盖)
java·开发语言·rust
MY_TEUCK1 天前
【Java 后端】SpringBoot 登录认证与会话跟踪实战(JWT + Filter/Interceptor)
java·开发语言·spring boot
今天长肉了吗1 天前
银行风控项目踩坑实录:指标跑了6小时,风险评分全挂了
java
随读手机1 天前
多式联运信息交互平台完整方案(2026版)
java·ai·eclipse·云计算·区块链
许彰午1 天前
03-二叉树——从递归遍历到非递归实现
java·算法
nj01281 天前
Spring 循环依赖详解:三级缓存、早期引用、AOP 代理与懒加载
java·spring·缓存
野生技术架构师1 天前
2026年最全Java面试题及答案汇总(建议收藏,面试前看这篇就够了)
java·开发语言·面试
一只叫煤球的猫1 天前
ThreadForge 源码解读一:ThreadScope 如何把并发任务放进清晰边界?
java·面试·开源
洛_尘1 天前
Python 5:使用库
java·前端·python
程序员小假1 天前
HTTP3 性能更好,为什么内网微服务依然多用 HTTP2?HTTP2 内网优势是什么?
java·后端