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

实现全局同步登出

相关推荐
禾小西2 小时前
Knife4j 快速入门:集Swagger2 和 OpenAPI3 为一体的增强解决方案
java·spring boot·后端
心勤则明2 小时前
Spring AI Alibaba MCP 协议的全链路安全与动态鉴权
java·安全·spring
sonnet-10292 小时前
堆排序算法
java·c语言·开发语言·数据结构·python·算法·排序算法
我是咸鱼不闲呀2 小时前
力扣Hot100系列24(Java)——[回溯]总结(下)(括号生成,单词搜索,分割回文串)
java·算法·leetcode
升鲜宝供应链及收银系统源代码服务2 小时前
生鲜配送供应链管理系统源代码之升鲜宝社区团购商城小程序(一)
java·前端·数据库·小程序·notepad++·供应链系统源代码·多门店收银系统
墨香幽梦客2 小时前
大数据环境下的BI架构:Hadoop与Spark的企业级应用整理
java·开发语言
lulu12165440782 小时前
IDEA+Claude Code智能辅助:保姆级高效开发教程
java·人工智能·intellij-idea·ai编程
曹牧2 小时前
Java:解析Json字符串格式要求
java·linux·运维·前端
REDcker2 小时前
Java 语言版本演进与特性概要
java·开发语言