Tomcat:The valid characters are defined in RFC 7230 and RFC 3986 問題處理

前段時間遇到這個問題:

包含json字符串類型的參數的http請求失敗,返回狀態碼400,提示invalid character found in the request target。

Tomcat在 7.0.73, 8.0.39, 8.5.7 版本後,添加了對於http頭的驗證。

新版本的Apache-tomcat-基本都覆蓋在內的,好 我們直接貼解決方法:

一:異常如下

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:483)
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:808)
at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1498)
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)

二:解決問題方式一

[zcjw@iZbp1f0xuq9rc41s6gdvfyZ conf]$ pwd
/usr/local/www/zcjw/apache-tomcat-8.5.43/conf

[zcjw@iZbp1f0xuq9rc41s6gdvfyZ conf]$ vi server.xml

修改成如下:
<Connector port="9199" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443"
			   relaxedQueryChars="[]|"
			   relaxedPathChars="[]|"
			   URIEncoding="UTF-8" />

加上這兩項,URLEncoding 沒有的話也要加上的

relaxedQueryChars="[]|"
relaxedPathChars="[]|"

問題處理成功。

三:解決問題方式二

[zcjw@iZbp1f0xuq9rc41s6gdvfyZ conf]$ pwd
/usr/local/www/zcjw/apache-tomcat-8.5.43/conf

[zcjw@iZbp1f0xuq9rc41s6gdvfyZ conf]$ vi catalina.properties

#修改成如下:
tomcat.util.http.parser.HttpParser.requestTargetAllow=|{}?&

重啓,然並卵 :
再試Tomcat VM啓動時加上這個:

[zcjw@iZbp1f0xuq9rc41s6gdvfyZ bin]$ ./startup.sh -Dcatalina.config /usr/local/www/zcjw/apache-tomcat-8.5.43/conf/catalina.properties

發現更改 catalina.properties 的方式根本沒有用,或者不是這麼用的。請在評論告訴我

方式二失敗

推薦大家使用方式一

 

參考來源:接口訪問報錯:The valid characters are defined in RFC 7230 and RFC 3986

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章