五月天青色头像情侣网名,国产亚洲av片在线观看18女人,黑人巨茎大战俄罗斯美女,扒下她的小内裤打屁股

歡迎光臨散文網(wǎng) 會(huì)員登陸 & 注冊(cè)

keycloak~自定義登出接口

2023-06-10 21:48 作者:bfyxzls  | 我要投稿

keycloak提供了登出的接口,不過(guò)它是一個(gè)post方法,需要你根據(jù)client_id,client_secret及refresh_token進(jìn)行登出操作的,有時(shí)不太靈活,所以我又自己封裝了一下,通過(guò)客戶端瀏覽器上存儲(chǔ)的session_id進(jìn)行會(huì)話登出。

kc提供的logout

  • api:{{host}}/auth/realms/fabao/protocol/openid-connect/logout

  • 請(qǐng)求方法:POST

  • 請(qǐng)求類型:x-www-form-urlencoded

  • 參數(shù):

refresh_token:xxx client_id:xxx client_secret:xxx

對(duì)remove-sessions登出的封裝

?// keycloak會(huì)話登出邏輯 ?@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);//清除會(huì)話 ? ?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); ? ?} ?}

通過(guò)上面的封裝,我們?cè)谄渌鼘?duì)應(yīng)到keycloak的客戶端,直接在瀏覽器上輸入/auth/realms/fabao/sms/remove-sessions?redirect_uri=your-site,就可以把keycloak在當(dāng)前瀏覽器里的會(huì)話登出了,并重定向到自己的you-site網(wǎng)站。


keycloak~自定義登出接口的評(píng)論 (共 條)

分享到微博請(qǐng)遵守國(guó)家法律
古交市| 韶关市| 靖江市| 什邡市| 盐池县| 西宁市| 个旧市| 大竹县| 灵川县| 安义县| 舒兰市| 于田县| 柳州市| 奉新县| 周宁县| 阿巴嘎旗| 静乐县| 龙泉市| 汉阴县| 梨树县| 赤城县| 嘉荫县| 崇义县| 根河市| 澄城县| 新巴尔虎右旗| 健康| 醴陵市| 视频| 黄浦区| 遂川县| 南江县| 闻喜县| 鹰潭市| 海原县| 晴隆县| 乌鲁木齐县| 民勤县| 昌平区| 泊头市| 广灵县|