Error parsing HTTP request header 错误解决方法
今天本地启动tomcat之后访问一个链接
http://localhost:8080/order/OrderInfoInFlowException.jsp?wareId=1&bookDate=2019-11-12
发现了一个很奇怪的现象,
org.apache.coyote.http11.Http11Processor.service Error parsing HTTP request header
Note: further occurrences of HTTP header 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:479)
at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:684)
at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)
at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:800)
at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1471)
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:748)
开始可能觉得是因为Tomcat的header缓冲区大小不够,所以在server.xml中增加maxHttpHeaderSize字段
<Connector connectionTimeout="20000" maxHttpHeaderSize="8999" port="8080" protocol="HTTP/1.1" redirectPort="8443"/>
发现还是不可以,后来看了这篇博客之后发现原来是tomcat高版本的问题,
高版本tomcat中的新特性:就是严格按照 RFC 3986规范进行访问解析,而 RFC
3986规范定义了Url中只允许包含英文字母(a-zA-Z)、数字(0-9)、-_.~4个特殊字符以及所有保留字符(RFC3986中指定了以下字符为保留字符:!
- ’ ( ) ; : @ & = + $ , / ? # [ ])。而我们的系统在通过地址传参时,在url中传了一段json,传入的参数中有”{“不在RFC3986中的保留字段中,所以会报这个错。
原文链接
因为我的实际请求是这个
http://localhost:8080/order/OrderExceptionAction/getNotSendWmsInfo.action?params={%22wareId%22:1,%22bookDate%22:%222019-11-12%22,%22obj%22:0}
很多字符是不符合的
然后根据这篇博客 中的方法更改了 catalina.properties 中的配置
tomcat.util.http.parser.HttpParser.requestTargetAllow=|{}
org.apache.tomcat.util.buf.UDecoder.ALLOW_ENCODED_SLASH=true
实测之后可用
还没有评论,来说两句吧...