Solucionado (ver solução)
Solucionado
(ver solução)
2
respostas

Utilizando o PathVariable com Spring

Criei uma busca de tópicos por nome o meu getDetalhesName ficou:

GetMapping("/detalhes/{name}") public DetalhesDoTopicoDto detalhesName(@PathVariable String name){ .... }

Se eu passo uma palavra com acento, não chama no método e retorna um erro 400, tbm não apresenta log de erro no Eclipse. Se eu passo a mesma palavra sem o acento tudo funciona.

Gostaria de saber se tem como eu configurar o serviço ou a aplicação para receber acento na uri.

2 respostas

Oi Fred,

Pode postar seu código completo aqui?

Não deveria dar problemas, pois o Spring Boot, por padrão, configura no tomcat o encoding de URI como UTF-8.

Eu testei aqui no meu projeto e funcionou normalmente passando uma String com acento no Path Variable.

solução!

Olá Rodrigo, obrigado pelo retorno.

O meu código

@GetMapping("/detalhes/{name}") public DetalhesDoTopicoDto detalhesName(@PathVariable String name) {

    DetalhesDoTopicoDto dto = new DetalhesDoTopicoDto(name);

    return dto;
}

Veio retorno no servidor sim, segue erro

2020-05-15 11:34:00.516 INFO 8856 --- [nio-8088-exec-4] o.apache.coyote.http11.Http11Processor : Error parsing HTTP request header Note: further occurrences of HTTP request parsing errors will be logged at DEBUG level.

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:474) ~[tomcat-embed-core-9.0.17.jar:9.0.17] at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:294) ~[tomcat-embed-core-9.0.17.jar:9.0.17] at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66) [tomcat-embed-core-9.0.17.jar:9.0.17] at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:834) [tomcat-embed-core-9.0.17.jar:9.0.17] at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1415) [tomcat-embed-core-9.0.17.jar:9.0.17] at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) [tomcat-embed-core-9.0.17.jar:9.0.17] at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) [na:1.8.0_11] at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) [na:1.8.0_11] at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) [tomcat-embed-core-9.0.17.jar:9.0.17] at java.lang.Thread.run(Thread.java:745) [na:1.8.0_11]

Retorno Postman