问题
笔者使用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
具体操作如下:
问题原因
问题产生原因是由于请求头的大小超过了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
原创不易
转载请标明出处
如果对你有所帮助 别忘啦点赞支持哈