Tomcat升级至7.0.96后报错:The valid characters are defined in RFC 7230 and RFC 3986

本文描述了从Tomcat7.0.11升级到7.0.96后遇到的URL解析错误,详细解释了错误原因在于高版本Tomcat严格按照RFC3986规范解析URL,不允许特定字符出现在请求目标中。并提供了修改catalina.properties文件中HttpParser.requestTargetAllow属性的解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题描述:

问题描述:近期安全整改,要将Tomcat7.0.11 升级至 7.0.96 版本,但是升级之后启动Tomcat发现程序无法访问,且Tomcat出现报错如下:

报错如下

INFO: Error parsing HTTP request header
 Note: further occurrences of HTTP header 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

问题原因

高版本tomcat中的新特性:就是严格按照 RFC 3986规范进行访问解,导致了一下字符问题:
This problem is a new feature in high-version tomcat: access parsing is strictly in accordance with RFC 3986 specification, which defines that only English letters (a-zA-Z), numbers (0-9), -. ~4 special characters and all reserved characters are allowed in Url (RFC 3986 specifies the following characters as reserved characters:!*’).( );: @ &= +$, /?# []. When our system passes through the address, it passes a JSON in the url. Among the parameters it passes in is "{not in the reserved field in RFC3986, so it will report this error.

解决办法:
找到…/conf/catalina.properties
最后一行
#tomcat.util.http.parser.HttpParser.requestTargetAllow=|
改成
tomcat.util.http.parser.HttpParser.requestTargetAllow=|{}
注意:去掉这行的注释。

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值