@Alecxandrys

Как прописать настройки tomcat в Java-конфиге?

День добрый,
Необходимо организовать правильное принятие параметров GET запроса, где может быть кириллица.
Сервис на Spring, в котором реализован RestController.
Метод с данной сигнатурой
@GetMapping(value = "/getDivisionByUniversity",consumes = "application/json;charset=UTF-8")
	public String getDivisionByUniversity(@RequestParam(defaultValue = "%") String university)


application.properties содержит следующие строки
#Charset of HTTP requests and responses. Added to the "Content-Type" header if not set explicitly.
spring.http.encoding.charset=UTF-8
# Enable http encoding support.
spring.http.encoding.enabled=true
# Force the encoding to the configured charset on HTTP requests and responses.
spring.http.encoding.force=true
server.tomcat.uri-encoding=UTF-8

Гугл указывает, к примеру, следующие:
Пункты 1 и 2
Через которые выходишь на следующее:
Инструкция

Вопрос:
1)Я правильно прописал настройки самого tomcat в application.properties или что то упустил при переносе конфигурации?
2)Как подцепить encoding filter, если вся конфигурация в java стиле? Класс фильтра есть, но куда его цеплять?
3) Что возможно ещё упускается мной при настройке поддержки кириллицы на tomcat?

Причина всего
spoiler
java.lang.IllegalArgumentException: Invalid character found in the request target. The valid characters are defined in RFC 7230 and RFC 3986
at org.apache.coyote.http11.Http11InputBuffer.parseRequestLine(Http11InputBuffer.java:472) ~[tomcat-embed-core-8.5.20.jar:8.5.20]
at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:683) ~[tomcat-embed-core-8.5.20.jar:8.5.20]
at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66) [tomcat-embed-core-8.5.20.jar:8.5.20]
at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:868) [tomcat-embed-core-8.5.20.jar:8.5.20]
at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1457) [tomcat-embed-core-8.5.20.jar:8.5.20]
at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) [tomcat-embed-core-8.5.20.jar:8.5.20]
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) [na:1.8.0_102]
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) [na:1.8.0_102]
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) [tomcat-embed-core-8.5.20.jar:8.5.20]
at java.lang.Thread.run(Thread.java:745) [na:1.8.0_102]
  • Вопрос задан
  • 656 просмотров
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы