解決 tomcat 解析 HTTP 請求 header 錯誤注意:HTTP請求解析錯誤的進一步發生將記錄在DEBUG級別。


錯誤信息如下:

23-Jun-2021 18:01:21.063 信息 [catalina-exec-25] org.apache.coyote.http11.Http11Processor.service 解析 HTTP 請求 header 錯誤注意:HTTP請求解析錯誤的進一步發生將記錄在DEBUG級別。
    java.lang.IllegalArgumentException: 在請求目標中找到無效字符。有效字符在RFC 7230和RFC 3986中定義
        at org.apache.coyote.http11.Http11InputBuffer.parseRequestLine(Http11InputBuffer.java:490)
        at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:261)
        at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65)
        at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:888)
        at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1597)
        at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
        at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
        at java.lang.Thread.run(Thread.java:748)

 

 

解決方案:

在tomcat8.5,tomcat7里面可行,解決辦法如下:

tomcat.util.http.parser.HttpParser.requestTargetAllow=|{}

 

tomcat9

在server.xml文件的Connector連接器中,增加這兩個屬性配置,key值為屬性名,value值是要過濾的字符串的值,配置如下:

relaxedPathChars="|{}[]^" relaxedQueryChars="|{}[]^"


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM