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

是非成败转头空 青山依旧在 几度夕阳红 。。。
随笔 - 1277, 文章 - 0, 评论 - 214, 阅读 - 321万
  博客园  :: 首页  :: 管理
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
复制代码
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="|{}[],%"/>

 

相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
历史上的今天:
2022-06-28 MySQL获取分组中的第一条数据和最后一条数据
2020-06-28 wpf 全局异常捕获处理
2007-06-28 通过HttpWebResponse和HttpWebRequest 获取http地址上的图片
2007-06-28 C# 一个多线程操作控件的例子.#######
点击右上角即可分享
微信分享提示