Spring Boot 项目请求参数丢失问题排查与解决

最近在项目中遇到一个 bug,涉及到文件另存接口无法正确读取前端传入的参数。以下是排查问题的过程:

  1. 在开发环境中通过 Postman 调用接口进入断点调试,没有问题,排除了接口本身的问题。

  2. 获取线上环境的入参,通过 Postman 调试发现取不到入参,怀疑参数的区别导致参数丢失。

  3. 参数唯一的区别是报错的参数报文较长。

  4. 怀疑是 Tomcat 配置问题,由于是 Spring Boot 项目,是嵌入式 Tomcat,参数的配置都要在 application.yml 中配置。

  5. 对比其他项目,没有缺少配置。

  6. 由于上面参数报文过长才导致的报错,怀疑是 Tomcat 有配置报文长度的限制,开始查阅资料。

  7. 找到了配置:

    server:
        port: 8080
        servlet:
            context-path: /demo
        tomcat:
            max-http-form-post-size: -1
    
  8. 加上配置,重启项目,经测试不再报错,问题解决。

在 Tomcat 中,max-http-form-post-size 是一个配置项,用于限制通过 HTTP POST 请求发送的表单数据的大小。将其设置为 -1 表示允许任意大小的表单数据。这对于希望完全放开表单数据大小限制的应用场景很有用。但需要注意,允许非常大的表单数据可能会导致服务器资源的过度使用,因此在生产环境中,可能会考虑设置一个合理的限制,以防止滥用。

以上是排查和解决问题的详细过程。在设计中,确保配置的大小限制不会对正常的用户体验造成不便是非常重要的。

你可能感兴趣的:(spring,boot,后端,java)