java.lang.IllegalArgumentException: Request header is too largeiseases

问题

笔者使用SpringBoot开发服务端项目,客户端发送请求控制台报错

java.lang.IllegalArgumentException: Request header is too largeiseases

详细问题

控制台详细报错如下

2024-01-20 18:44:46.541  INFO 16344 --- [nio-9090-exec-4] o.apache.coyote.http11.Http11Processor   : Error parsing HTTP request header
 Note: further occurrences of HTTP request parsing errors will be logged at DEBUG level.

java.lang.IllegalArgumentException: Request header is too large
	at org.apache.coyote.http11.Http11InputBuffer.fill(Http11InputBuffer.java:790) ~[tomcat-embed-core-9.0.56.jar:9.0.56]
	at org.apache.coyote.http11.Http11InputBuffer.parseRequestLine(Http11InputBuffer.java:454) ~[tomcat-embed-core-9.0.56.jar:9.0.56]
	at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:269) ~[tomcat-embed-core-9.0.56.jar:9.0.56]
	at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65) ~[tomcat-embed-core-9.0.56.jar:9.0.56]
	at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:895) ~[tomcat-embed-core-9.0.56.jar:9.0.56]
	at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1732) ~[tomcat-embed-core-9.0.56.jar:9.0.56]
	at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) ~[tomcat-embed-core-9.0.56.jar:9.0.56]
	at org.apache.tomcat.util.threads.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1191) ~[tomcat-embed-core-9.0.56.jar:9.0.56]
	at org.apache.tomcat.util.threads.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:659) ~[tomcat-embed-core-9.0.56.jar:9.0.56]
	at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) ~[tomcat-embed-core-9.0.56.jar:9.0.56]
	at java.base/java.lang.Thread.run(Thread.java:834) ~[na:na]

解决方案

项目名\src\main\resources\application.yml的server配置下增加:

server:
  max-http-header-size: 10000000

若使用application.properties为配置文件:

server.max-http-header-size=10000000 

具体操作如下:
java.lang.IllegalArgumentException: Request header is too largeiseases_第1张图片

问题原因

问题产生原因是由于请求头的大小超过了Tomcat默认的限制,导致无法正常解析请求头而抛出 java.lang.IllegalArgumentException: Request header is too large 异常。

解决原因

在Spring Boot项目中,开发者可以通过调整Tomcat的配置来解决该问题。

在开发者的 application.yml 或 application.properties 中,可以添加以下配置来增加请求头的最大大小:

YAML 格式:

server:
  max-http-header-size: 10000000

Properties 格式:

server.max-http-header-size=10000000

这样的配置会告诉Tomcat允许的最大请求头大小为 10 MB。当然,开发者可以根据实际需求调整这个值。值得一提的是,增加请求头大小可能会导致一些安全隐患,譬如拒绝服务攻击,内存消耗,缓冲区溢出,网络带宽占用,HTTP请求解析性能等。

参加文献

JAVA -tomcat- Request header is too large
产生原因与解决原因部分内容 部分参考chatgpt

原创不易
转载请标明出处
如果对你有所帮助 别忘啦点赞支持哈
请添加图片描述

你可能感兴趣的:(java,开发语言)