【发布时间】:2019-06-14 17:20:10
【问题描述】:
我的程序在网上抛出这个异常,我知道是什么原因出错了。 我的问题是如何找到错误的位置,Java 无法捕获此异常的位置。 如何获取有关此异常的其他信息,例如此错误请求地址的 API。
错误信息如下:
2019-01-18 07:49:23.076 [http-nio-127.0.0.1-8081-exec-96] INFO org.apache.coyote.http11.Http11Processor - 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:484)
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(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Unknown Source)
【问题讨论】:
-
该类 github.com/apache/tomcat/blob/trunk/java/org/apache/coyote/… 中似乎有调试语句。当您启用名称为
org.apache.coyote.http11.Http11InputBuffer的调试记录器时,您应该能够看到问题所在 -
由于在线,所以没有开启调试模式。