报错信息:2024-4-19 11:12:11 org.apache.coyote.http11.AbstractHttp11Processor process
信息: 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.InternalInputBuffer.parseRequestLine(InternalInputBuffer.java:192)
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1028)
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:637)
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:318)
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:895)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:918)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:662)
发生这个报错的可能原因:
1.可能是请求路径过长导致
具体的url的长度请大家自行去查询,每一个浏览器的限制是不同的。
2.路径中含有非法字符
Tomcat在Tomcat 7.0.73+,Tomcat 8.0.39+,Tomcat 8.5.7+,Tomcat 9.0.0.M12 (markt)+版本后,在http url解析时做了严格字符限制,url包含特殊字符将直接返回http code 400
解决方案:
在tomcat文件下的conf /catalina.properties中添加如下 代码(官方文档)
tomcat.util.http.parser.HttpParser.requestTargetAllow=|{}
org.apache.tomcat.util.buf.UDecoder.ALLOW_ENCODED_SLASH=true
tomcat.util.http.parser.HttpParser.requestTargetAllow=|{} 后加入其它字符比如 [],根据自己需求添加。
2.第二方案
在第一方案后,又修改了在tomcat文件下的conf /server 中 Connector标签内添加如下代码(设置tomcat端口号地方)
relaxedPathChars="],[[ \ ]: ^ ` { | }"
relaxedQueryChars="],[:[ \ ] ^ ` { | }"
注:具体想了解这几个属性的可以参考官网。基本就是在允许url中可以携带这些特殊字符。
3.http的头解析错误,将会在调试的时候记录
https 改为http 或者 http 改为 https
4.Tomcat的header缓冲区大小不够
<Connector URIEncoding="UTF-8" port="8080" protocol="org.apache.coyote.http11.Http11NioProtocol" useBodyEncodingForURI="false" enableLookups="false" connectionTimeout="20000" redirectPort="8443" maxHttpHeaderSize="你想要的大小"/>
博主自己的问题:
我最开始用的tomcat版本是tomcat7.0.84,如上所说在7.0.73以上的版本对url的特殊字符做出了限制,所以报了以上的错误。因为我们项目版本特定原因不能使用太低的版本所以我找了一个tomcat7.0.70版本,完美的解决了以上问题。
奉上tomcat7.0.70的下载链接:
https://archive.apache.org/dist/tomcat/tomcat-7/v7.0.70/bin/
点击即可下载
大家自行参考如果有帮助点赞支持一下哦~,谢谢。