Как изменить максимальный размер заголовка при выходе из Keycloak?

Я использую Keycloak для аутентификации в своем приложении Spring Boot 3. При запросе на выход из системы я получаю сообщение 431 Request Header Fields Too Large . Это происходит не с обычными пользователями, а только с пользователями-разработчиками, у которых есть 260 ролей. Я пыталсяserver.max-http-request-header-size=20KB server.tomcat.max-http-response-header-size=20KB, но они не решают проблему. В этой строке выдается исключение: ResponseEntity logoutResponse = restTemplate.getForEntity(builder.toUriString(), String.class);

      @Component
public class KeycloakLogoutHandler implements LogoutHandler {

    private final RestTemplate restTemplate;

    @Autowired
    public KeycloakLogoutHandler(RestTemplateBuilder builder) {
        this.restTemplate = builder.build();
    }

    @Override
    public void logout(HttpServletRequest request, HttpServletResponse response, Authentication auth) {
        logoutFromKeycloak((OidcUser) auth.getPrincipal());
    }

    private void logoutFromKeycloak(OidcUser user) {
        String endSessionEndpoint = user.getIssuer() + "/protocol/openid-connect/logout";
        UriComponentsBuilder builder = UriComponentsBuilder
                .fromUriString(endSessionEndpoint)
                .queryParam("id_token_hint", user.getIdToken().getTokenValue());

        **ResponseEntity<String> logoutResponse = restTemplate.getForEntity(builder.toUriString(), String.class);**
        if (logoutResponse.getStatusCode().is2xxSuccessful()) {
            log.info("Successfully logged out from Keycloak");
        } else {
            log.error("Could not propagate logout to Keycloak");
        }
    }

}

0 ответов

Другие вопросы по тегам