明天的明天 永远的永远 未知的一切 我与你一起承担 ??

是非成败转头空 青山依旧在 几度夕阳红 。。。
  博客园  :: 首页  :: 管理
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="|{}[],%"/>