我的請(qǐng)求URL中有字符[和],項(xiàng)目部署在Tomcat8.5.33上。當(dāng)我發(fā)布請(qǐng)求時(shí)會(huì)發(fā)生一些異常。20-Sep-2018 10:55:36.494 WARNING [http-nio-8075-exec-2] org.apache.tomcat.util.http.parser.HttpParser.<clinit> Character [[] is not allowed and will continue to be rejected.20-Sep-2018 10:55:36.494 WARNING [http-nio-8075-exec-2] org.apache.tomcat.util.http.parser.HttpParser.<clinit> Character []] is not allowed and will continue to be rejected.20-Sep-2018 10:56:07.083 INFO [http-nio-8075-exec-10] 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:806) 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: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)
2 回答

qq_花開(kāi)花謝_0
TA貢獻(xiàn)1835條經(jīng)驗(yàn) 獲得超7個(gè)贊
在我的請(qǐng)求 URL 中有字符
[
和]
....
這是真正的問(wèn)題。您正在向您的服務(wù)器發(fā)送一個(gè)帶有無(wú)效 URL 的請(qǐng)求。有效的 URL 不能包含[
和]
...,主機(jī)部分的 IP 文字除外。在所有其他情況下,它們必須是 %-escaped。
在正確的解決方法是修復(fù)你的URL和/或生成它們?cè)诳蛻?hù)端軟件。
Tomcat 只是強(qiáng)制執(zhí)行 URL / URI 規(guī)范中的規(guī)則……這些規(guī)則在過(guò)去 20 多年左右的時(shí)間里一直存在于規(guī)范中。
添加回答
舉報(bào)
0/150
提交
取消