Tomcat8中URI不支持{}|等特殊字符解决方案

本文探讨了Tomcat 8.5版本对于含有未编码中文字符的GET请求处理方式及出现的问题,包括拦截请求并返回400错误的原因。提供了多种解决策略,如更新配置文件、前端URL编码、更改请求方法等。

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

Tomcat8.5,当Get请求中包含了未经编码的中文字符时,会报以下错误,请求未到应用程序在Tomcat层就被拦截了。
Tomcat报错:

java.lang.IllegalArgumentException: Invalid character found in the request target. 
The valid characters are defined in RFC 7230 and RFC 3986

返回400错误:

Transfer-Encoding—>[chunked]
null—>[HTTP/1.1 400 Bad Request]
Server—>[Apache-Coyote/1.1]
Connection—>[close]
Date—>[Wed, 07 Feb 2018 03:19:04 GMT]

原因
由于tomcat 新版本 增加一个特性: 严格按照RFT 3986规范定义了Url
RFC规范
Url中只允许包含英文字母(a-zA-Z)、数字(0-9)、-_.~4个特殊字符以及所有保留字符(RFC3986中指定了以下字符为保留字符:! * ’ ( ) ; : @ & = + $ , / ? # [ ])

查源码发现在Tomcat7.0.73 就已经添加了RFC 3986这个规范。

解决方案
a. 降低tomcat的版本 切换版本到7.0.73以下,这个不实际。
b. 采用最新tomcat版本。对请求链接进行编码,并修改对应的过滤器,对所有请求链接进行编码解析处理。
c. 前端请求对URL编码
d. 修改Get方法为Post方法
e. catalina.properties 中最后追加 tomcat.util.http.parser.HttpParser.requestTargetAllow=|{}


  • Spring Boot 内嵌tomcat的解决方案
    在SpringBootApplication的的main方法中增加
    System.setProperty("tomcat.util.http.parser.HttpParser.requestTargetAllow","|{}");
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

讓丄帝愛伱

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值