版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/zc_ad/article/details/83344036
以前写代码的时候遇到一个很懵逼的错误,如标题所说。不知道为什么会出现这个错误。后来发现是uri中有中文导致的。错误日志:
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)
at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:683)
at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)
at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:868)
at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1455)
at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:745)
修改办法很简单,只需要将1.uri中的中文字符去掉即可;2.请求从get变为post;3.降低tomcat版本。
方法一:去掉中文字符(推荐这样使用)
我原本的请求uri是这样的:/user/张三/info,这样写及其不规范,应该改为/user/info,然后将参数写在@RequestParam("name")中。请求代码前后对比:
/**不规范写法*/
@GetMapping("/user/{name}/info")
public Object userInfo(@PathVariable("name")String name){
...
...
}
/**正确写法*/
@GetMapping("/user/info")
public Object userInfo(@RequestParam("name")String name){
...
...
}
方法二:将请求由get变为post,自测可以消除这个问题(不建议这样使用)
/**修改前*/
@GetMapping("/user/{name}/info")
public Object userInfo(@PathVariable("name")String name){
...
...
}
/**修改后*/
@PostMapping("/user/info")
public Object userInfo(@RequestParam("name")String name){
...
...
}
方法三:降低tomcat版本,自测也可以消除这个错误(不建议这样使用)
本人使用的是springboot,只需要在maven依赖中添加以下代码即可:
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<tomcat.version>8.0.29</tomcat.version>
</properties>