Note: further occurrences of HTTP request parsing errors will be logged at DEBUG level.
java.lang.IllegalArgumentException: Invalid character found in the request target. The valid characters are defined in RFC 7230 and RFC 3986
1:无效字符
Tomcat在 7.0.73、8.0.39、8.5.7 版本后,添加了对于http头的验证,具体来说,就是添加了些规则去限制HTTP头的规范性
不安全字符
还有一些字符,当他们直接放在Url中的时候,可能会引起解析程序的歧义。这些字符被视为不安全字符,原因有很多。
空格,Url在传输的过程,或者用户在排版的过程,或者文本处理程序在处理Url的过程,都有可能引入无关紧要的空格,或者将那些有意义的空格给去掉
<>引号和尖括号通常用于在普通文本中起到分隔Url的作用
通常用于表示书签或者锚点
% 百分号本身用作对不安全字符进行编码时使用的特殊字符,因此本身需要编码
{ } | \ ^ [ ]` ~ 某一些网关或者传输代理会篡改这些字符
解决问题: 前端复制新增数据 修改的时候 对应的一个参数
name:就是下面这种格式 就是无效字符 (前端说 他copy了 编辑 就好了 )
[{“name”:“¥30万”,“parsernt”:“1.5%”,“desc”:“0%”,“isOK”:false},{“date”:"",“isOK”:false,“name”:“¥100万”,“address”:"",“parsernt”:“1.8%”,“desc”:“0%”},{“date”:"",“isOK”:false,“name”:“¥300万”,“address”:"",“parsernt”:“2%”,“desc”:"\t0%"}]
1:编码
2:转换字符(如果 参数进不了接口 就是前端才能修改了)
3:长度注意
(前端说 他copy了 编辑 就好了 )