Tomcat 在请求目标中找到无效字符。有效字符在RFC 7230和RFC 3986中定义
Posted on 2023-06-28 22:33 且行且思 阅读(793) 评论(0) 编辑 收藏 举报HTTP状态 400 - 错误的请求 类型 异常报告 消息 在请求目标中找到无效字符[/iserver/manager/filechooser?extensions=sci|inf&refer=D: ]。有效字符在RFC 7230和RFC 3986中定义 描述 由于被认为是客户端对错误(例如:畸形的请求语法、无效的请求信息帧或者虚拟的请求路由),服务器无法或不会处理当前请求。 例外情况 java.lang.IllegalArgumentException: 在请求目标中找到无效字符[/iserver/manager/filechooser?extensions=sci|inf&refer=D: ]。有效字符在RFC 7230和RFC 3986中定义 org.apache.coyote.http11.Http11InputBuffer.parseRequestLine(Http11InputBuffer.java:497) org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:492) org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:63) org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:932) org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1695) org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:52) org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) java.lang.Thread.run(Unknown Source) ):注意 主要问题的全部 stack 信息可以在 server logs 里查看
原因分析:
是因为 日志显示请求地址中包含不合法字符,出现400错误
tomcat高版本严格按照RFC 3986规范解析地址。该规范只允许包含 a-zA-Z 0-9 - _ . ~ 以及所有保留字符 ! * ’ ( ) ; : @ & = + $ , / ? # [ ]
但是项目在发起请求的参数中出现{},所以需要配置一下
解决方法:
网上最多采用的方法,将tomcat中的server.xml文件添加如下配置:
relaxedPathChars="|{}[],%" relaxedQueryChars="|{}[],%"
在tomcat配置文件中做出以下配置,找到tomcat配置中的server.xml路径就在conf
文件夹下
加上红色框中的代码 问题解决。或者替换以上的代码也可。
<Connector connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443" URIEncoding="UTF-8" relaxedPathChars="|{}[],%" relaxedQueryChars="|{}[],%"/>