最近在项目中遇到一个 bug,涉及到文件另存接口无法正确读取前端传入的参数。以下是排查问题的过程:
-
在开发环境中通过 Postman 调用接口进入断点调试,没有问题,排除了接口本身的问题。
-
获取线上环境的入参,通过 Postman 调试发现取不到入参,怀疑参数的区别导致参数丢失。
-
参数唯一的区别是报错的参数报文较长。
-
怀疑是 Tomcat 配置问题,由于是 Spring Boot 项目,是嵌入式 Tomcat,参数的配置都要在
application.yml
中配置。 -
对比其他项目,没有缺少配置。
-
由于上面参数报文过长才导致的报错,怀疑是 Tomcat 有配置报文长度的限制,开始查阅资料。
-
找到了配置:
yamlserver: port: 8080 servlet: context-path: /demo tomcat: max-http-form-post-size: -1
-
加上配置,重启项目,经测试不再报错,问题解决。
在 Tomcat 中,max-http-form-post-size
是一个配置项,用于限制通过 HTTP POST 请求发送的表单数据的大小。将其设置为 -1
表示允许任意大小的表单数据。这对于希望完全放开表单数据大小限制的应用场景很有用。但需要注意,允许非常大的表单数据可能会导致服务器资源的过度使用,因此在生产环境中,可能会考虑设置一个合理的限制,以防止滥用。
以上是排查和解决问题的详细过程。在设计中,确保配置的大小限制不会对正常的用户体验造成不便是非常重要的。