报错信息如下:
java.lang.IllegalArgumentException: Invalid character found in the request target. The valid characters are defined in RFC 7230 and RFC 3986
在网上搜索了很久都是两种解决方案,解决的是{}报错的问题
解决方案大致分为两种
1. 在properties文件中添加
tomcat.util.http.parser.HttpParser.requestTargetAllow=|{}
2. 在properties文件中添加
org.apache.tomcat.util.buf.UDecoder.ALLOW_ENCODED_SLASH=true
但是上面的两种方案都没有解决我的问题。
最后发现两种解决方案
1. 前端通过URL转码的方式将[]转码为%5b和%5d即可
2. 修改Tomcat版本
Tomcat版本升级之后对URL的验证加强,降低Tomcat的版本可以解决URL非法字符的问题
本人是用的springboot集成的Tomcat,所以需要先查询当前Tomcat的版本
- 打开maven资源库路径下的org\springframework\boot\spring-boot-dependencies\
- 查看pom文件中springboot的版本,当前为<version>2.0.3.RELEASE</version>
- 所以打开2.0.3.RELEASE,查看spring-b