tomcat 处理url特殊字符
2023-04-18 14:25:50 时间
tomcat版本:7.0.93
报错信息如下:
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
at org.apache.coyote.http11.InternalInputBuffer.parseRequestLine(InternalInputBuffer.java:194)
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1050)
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:637)
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:317)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:748)
具体分析如下:
tomcat添加了对header请求头的验证,因请求路径中带有[]{}等字符,所以无法通过校验。
解决方案:
1、去除URL中的特殊字符;
2、使用 Post 方法提交数据
3、更换低版本的Tomcat来规避这种问题。
4、在 conf/catalina.properties 添加或者修改:
tomcat.util.http.parser.HttpParser.requestTargetAllow=|{}
该配置只对以上三种特定字符有效。
5、在 conf/server.xml <Connector> 节点下添加:
relaxedPathChars="|{}[],%"
relaxedQueryChars="|{}[],%"
如下:
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443"
relaxedPathChars=""<>[\]^`{|}"
relaxedQueryChars=""<>[\]^`{|}" />
如果是springboot项目则将webServerFactory方法加入到springboot启动类
@Configuration
public class TomcatConfig {
@Bean
public TomcatServletWebServerFactory webServerFactory() {
TomcatServletWebServerFactory factory = new TomcatServletWebServerFactory();
factory.addConnectorCustomizers((Connector connector) -> {
connector.setProperty("relaxedPathChars", ""<>[\]^`{|}");
connector.setProperty("relaxedQueryChars", ""<>[\]^`{|}");
});
return factory;
}
}
经测试之后,该问题解决!
ps :如何解决tomcat乱码问题
在Connector节点下添加属性 URIEncoding="UTF-8"即可。
相关文章
- 在Java中实现两数相乘
- Java 仿 Excel 公式计算
- JAVA验证多个参数,类似多个变量的异或XOR但不一样。解决多于2个true返回true,而不是false
- Java常用类--Math类
- 基于java的网上银行(网银)管理系统
- Java性能优化-竞争中的原子类
- CC链总结
- macOS系统下的jdk环境配置步骤(超级详细)
- Java基础:进制之间的转换,8421码,原码,反码,补码
- java基础:值传递与引用传递
- 如何在 Mac 上卸载 Java?
- 解决Build failed:Could not resolve com.android.tools.build:gradle:7.4.0-alpha10.
- Servlet | Servlet原理、开发第一个带有Java小程序Servlet
- Spring Cloud Alibaba 微服务1,系统架构演变 + Nginx反向代理与负载均衡
- Java性能-线程和同步性能-线程同步
- Java面向对象编程,绘制思维导图(全面详细整理)
- Java按键事件KeyEvent
- JAVA中的标识符
- 【Java实现文件上传】java后端+vue前端实现文件上传全过程详解(附源码)
- java的main方法中的参数有什么用