问题表象
开发,测试环境运行正常的接口到现场报错,报错日志关键信息如下:java.lang.IllegalArgumentException: Invalid character found in the request target. The valid characters are defined in RFC 7230 and RFC 3986。
问题分析及原因
由于代码在开发测试环境测试通过,判断大概率是现场特殊数据导致问题。查资料得知,如果Get请求的参数包含了特殊字符会引起上文中的报错。向现场确认,查看请求数据,发现参数中存在“[]”特殊字符。
出于网络安全考虑,Web容器默认是不允许Url中存在特殊字符的,对应的字符标准是RFC7230和RFC3986,一旦Url中出现了不符合标准的字符就会报这个异常。
解决方案
方案1:(采用的方案)
修改配置,项目用的是spring-boot内置的tomcat,增加spring配置
server.tomcat.relaxed-query-chars=<,>,[,\,\,],^,`,{,|,}
这个参数控制的是普通参数如果使用路径参数需要增加如下配置
server.tomcat.relaxed-path-chars=<,>,[,\,\,],^,`,{,|,}
方案2:
将Get请求改成Post请求。
方案3:
修改出错的接口,前端对参数进行编码,屏蔽特殊字符,后端解码。