今天发现一个问题,项目在我本地以及正式环境单机访问都是没有问题的,但是通过nginx统一访问,就会报如下错误:org.apache.tomcat.util.http.parser.HttpParser.<clinit> Character ["] is not allowed and will continue to be rejected.
java.lang.IllegalArgumentException: Invalid character found in the request target. The valid characters are defined in RFC 7230 and RFC 3986
org.apache.tomcat.util.http.parser.HttpParser.<clinit> Character ["] is not allowed and will continue to be rejected.
java.lang.IllegalArgumentException: Invalid character found in the request target. The valid characters are defined in RFC 7230 and RFC 3986
通过错误了解到 项目请求路径中包含 json字符串的信息,其中包含了特殊符号。由于7.x及以后版本对url的参数做了比较规范的限制,所以必须按照RFC 7230 and RFC 3986规范,对于非保留字字符,如果不做转义处理,一律都会报The valid characters are defined in RFC 7230 and RFC 3986 错误。
通过查阅相关资料如下办法解决了该问题:
1. 编辑Tomcat /config/catalina.properties 配置文件,找到 tomcat.util.http.parser.HttpParser.requestTargetAllow=|,解开注释,并配置tomcat.util.http.parser.HttpParser.requestTargetAllow=|{}。(此属性只支持| { } 三种字符)。
2. 同时在catalina.properties配置文件中增加属性:org.apache.tomcat.util.buf.UDecoder.ALLOW_ENCODED_SLASH=true。
3. 在/config/server.xml 的Connector节点中增加 relaxedPathChars='\":' relaxedQueryChars='\":' ,其中relaxedPathChars 和 relaxedQueryChars中配置你想要支持的字符。
修改完以上配置,然后重新启动tomcat ,我的问题就解决了。
Tomcat 配置项:https://tomcat.apache.org/tomcat-8.5-doc/config/systemprops.html
我的Tomcat版本是apache-tomcat-8.5.39。 至于为什么我单机访问项目就没问题,而通过nginx访问就有问题。这个目前还没发现具体原因所在, 也希望有知道朋友,欢迎指点。
参考:https://blog.csdn.net/u010170616/article/details/80832108