在使用SpringBoot和静态页面异步获取数据时,js调用端口时报400,日志查看到错误提示:nvalid character found in the request target. The valid characters are defined in RFC 3986
大概意思是字符为非3986中定义的有效字符
RFC3986中指定了以下字符为保留字符:! * ’ ( ) ; : @ & = + $ , / ? # [ ]
不安全字符:还有一些字符,当他们直接放在Url中的时候,可能会引起解析程序的歧义。这些字符被视为不安全字符,原因有很多。
- 空格:Url在传输的过程,或者用户在排版的过程,或者文本处理程序在处理Url的过程,都有可能引入无关紧要的空格,或者将那些有意义的空格给去掉。
- 引号以及<>:引号和尖括号通常用于在普通文本中起到分隔Url的作用
- #: 通常用于表示书签或者锚点
- {}|\^[]`~:某一些网关或者传输代理会篡改这些字符
一个行之有效的解决方法
前端JS对请求地址中的非法字符进行转移,使用encodeURI方法:
url = url + '/name=' + encodeURI('方')