keycloak~自定义登出接口
keycloak提供了登出的接口,不过它是一个post方法,需要你根据client_id,client_secret及refresh_token进行登出操作的,有时不太灵活,所以我又自己封装了一下,通过客户端浏览器上存储的session_id进行会话登出。
kc提供的logout
- api:{{host}}/auth/realms/fabao/protocol/openid-connect/logout
- 请求方法:POST
- 请求类型:x-www-form-urlencoded
- 参数:
refresh_token:xxx
client_id:xxx
client_secret:xxx
对remove-sessions登出的封装
// keycloak会话登出逻辑
@GET
@NoCache
@Path("remove-sessions")
public Response deleteSession(@Context HttpRequest request,
@QueryParam("redirect_uri") String redirectUri) {
return removeSession(TokenUtils.getKeycloakSessionIdFromCookies(request), redirectUri);
}
private Response removeSession(String sessionId, String redirectUri) {
if (redirectUri == null || redirectUri.trim().length() == 0) {
log.info("redirect_uri不正确");
return Response.status(400).entity("redirect_uri不正确").type(MediaType.TEXT_HTML).build();
}
TokenUtils.removeSession(session, sessionId);//清除会话
return Response.status(302)
.location(HttpUtils.formatUrl(HttpUtils.removeUrlSpaceParams(redirectUri)))
.cookie(CookieUtils.addCookie(TokenUtils.KC_EXIT_LEGACY, "1"))
.header(HttpHeaders.SET_COOKIE,
CookieUtils.cookieString(TokenUtils.KC_EXIT, "1", "/", null, null, -1, true, true,
ServerCookie.SameSiteAttributeValue.NONE))
.build();
}
public static void removeSession(KeycloakSession session, String sessionId) {
try {
if (sessionId != null) {
RealmModel realmModel = session.getContext().getRealm();
log.debugf("will remove sessionId:%s", sessionId);
UserSessionModel userSession = session.sessions().getUserSession(session.getContext().getRealm(), sessionId);
if (userSession != null) {
String path = String.format("/auth/realms/%s/", session.getContext().getRealm().getId());
CookieUtils.expireCookie(session.getContext().getRealm(), TokenUtils.KEYCLOAK_SESSION,
path, null, false,
session.getContext().getConnection(), ServerCookie.SameSiteAttributeValue.NONE);
CookieUtils.expireCookie(session.getContext().getRealm(), TokenUtils.KEYCLOAK_SESSION_LEGACY, path, null,
false,
session.getContext().getConnection(), null);
CookieUtils.expireCookie(session.getContext().getRealm(), TokenUtils.AUTH_SESSION_ID,
path, null, false,
session.getContext().getConnection(), ServerCookie.SameSiteAttributeValue.NONE);
CookieUtils.expireCookie(session.getContext().getRealm(), TokenUtils.AUTH_SESSION_ID_LEGACY, path, null,
false,
session.getContext().getConnection(), null);
AuthenticationManager.backchannelLogout(session,
realmModel,
userSession,
session.getContext().getUri(),
session.getContext().getConnection(),
session.getContext().getRequestHeaders(),
true);
}
}
} catch (Exception ex) {
log.error(ex);
}
}
通过上面的封装,我们在其它对应到keycloak的客户端,直接在浏览器上输入/auth/realms/fabao/sms/remove-sessions?redirect_uri=your-site
,就可以把keycloak在当前浏览器里的会话
登出了,并重定向到自己的you-site网站。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 记一次.NET内存居高不下排查解决与启示
2019-05-31 二叉树的遍历和查找
2017-05-31 Linux~Sh脚本一点自己的总结
2016-05-31 DotNetCore跨平台~Startup类的介绍
2012-05-31 架构,改善程序复用性的设计~第四讲 方法的重载真的用不到吗?
2011-05-31 项目中的通用消息类的实现