keycloak~自定义登出接口

打印 上一主题 下一主题

主题 887|帖子 887|积分 2661

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
  • 参数:
  1. refresh_token:xxx
  2. client_id:xxx
  3. client_secret:xxx
复制代码
对remove-sessions登出的封装
  1.   // keycloak会话登出逻辑
  2.   @GET
  3.   @NoCache
  4.   @Path("remove-sessions")
  5.   public Response deleteSession(@Context HttpRequest request,
  6.                                 @QueryParam("redirect_uri") String redirectUri) {
  7.     return removeSession(TokenUtils.getKeycloakSessionIdFromCookies(request), redirectUri);
  8.   }
  9. private Response removeSession(String sessionId, String redirectUri) {
  10.     if (redirectUri == null || redirectUri.trim().length() == 0) {
  11.       log.info("redirect_uri不正确");
  12.       return Response.status(400).entity("redirect_uri不正确").type(MediaType.TEXT_HTML).build();
  13.     }
  14.     TokenUtils.removeSession(session, sessionId);//清除会话
  15.     return Response.status(302)
  16.         .location(HttpUtils.formatUrl(HttpUtils.removeUrlSpaceParams(redirectUri)))
  17.         .cookie(CookieUtils.addCookie(TokenUtils.KC_EXIT_LEGACY, "1"))
  18.         .header(HttpHeaders.SET_COOKIE,
  19.             CookieUtils.cookieString(TokenUtils.KC_EXIT, "1", "/", null, null, -1, true, true,
  20.                 ServerCookie.SameSiteAttributeValue.NONE))
  21.         .build();
  22. }
  23. public static void removeSession(KeycloakSession session, String sessionId) {
  24.     try {
  25.       if (sessionId != null) {
  26.         RealmModel realmModel = session.getContext().getRealm();
  27.         log.debugf("will remove sessionId:%s", sessionId);
  28.         UserSessionModel userSession = session.sessions().getUserSession(session.getContext().getRealm(), sessionId);
  29.         if (userSession != null) {
  30.           String path = String.format("/auth/realms/%s/", session.getContext().getRealm().getId());
  31.           CookieUtils.expireCookie(session.getContext().getRealm(), TokenUtils.KEYCLOAK_SESSION,
  32.               path, null, false,
  33.               session.getContext().getConnection(), ServerCookie.SameSiteAttributeValue.NONE);
  34.           CookieUtils.expireCookie(session.getContext().getRealm(), TokenUtils.KEYCLOAK_SESSION_LEGACY, path, null,
  35.               false,
  36.               session.getContext().getConnection(), null);
  37.           CookieUtils.expireCookie(session.getContext().getRealm(), TokenUtils.AUTH_SESSION_ID,
  38.               path, null, false,
  39.               session.getContext().getConnection(), ServerCookie.SameSiteAttributeValue.NONE);
  40.           CookieUtils.expireCookie(session.getContext().getRealm(), TokenUtils.AUTH_SESSION_ID_LEGACY, path, null,
  41.               false,
  42.               session.getContext().getConnection(), null);
  43.           AuthenticationManager.backchannelLogout(session,
  44.               realmModel,
  45.               userSession,
  46.               session.getContext().getUri(),
  47.               session.getContext().getConnection(),
  48.               session.getContext().getRequestHeaders(),
  49.               true);
  50.         }
  51.       }
  52.     } catch (Exception ex) {
  53.       log.error(ex);
  54.     }
  55.   }
复制代码
通过上面的封装,我们在其它对应到keycloak的客户端,直接在浏览器上输入/auth/realms/fabao/sms/remove-sessions?redirect_uri=your-site,就可以把keycloak在当前浏览器里的会话登出了,并重定向到自己的you-site网站。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

愛在花開的季節

金牌会员
这个人很懒什么都没写!
快速回复 返回顶部 返回列表