Tomcat 中请求 header 中的特殊字符问题 9

Problem with special characters in request header in Tomcat 9

最近从 Tomcat 8 升级到 Tomcat 9 后,我遇到了具有特殊字符的请求 header 的问题,对于我的情况是“<”和“>”人物。错误说 "Invalid character found in the request target. The valid characters are defined in RFC 7230 and RFC 3986"

我试图四处寻找一种方法并偶然发现了一个解决方案,它说我可以将 "relaxedQueryChars="<,>" 添加到我服务器的 server.xml 中,但这个解决方案的问题是我们'不允许编辑服务器中的任何内容,因为它由 puppet 管理,因此每次都会被覆盖。

有没有办法在我的应用程序中添加 relaxedQueryChars="<,>" 而不是在服务器中添加? context.xml 或 web.xml 之类的地方,我真的不知道。

错误信息:

java.lang.IllegalArgumentException: Invalid character found in the request target. The valid characters are defined in RFC 7230 and RFC 3986
    org.apache.coyote.http11.Http11InputBuffer.parseRequestLine(Http11InputBuffer.java:467)
    org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:294)
    org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)
    org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:834)
    org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1415)
    org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
    java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1128)
    java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:628)
    org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
    java.base/java.lang.Thread.run(Thread.java:834)

抱歉,没有。 relaxedQueryChars 是连接器属性,因此只能在 server.xml 中设置。

可能的选项包括:

  • 修复应用程序以对这些字符进行编码
  • 更新 Puppet 配置以设置 relaxedQueryChars
  • 所需的值