报错:java.lang.IllegalArgumentException

问题表象

开发,测试环境运行正常的接口到现场报错,报错日志关键信息如下: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:
修改出错的接口,前端对参数进行编码,屏蔽特殊字符,后端解码。

你可能感兴趣的:(问题总结,java,开发语言)