news 2026/4/16 13:54:17

Undertow不支持大文件上传,使用application.yml配置失效

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Undertow不支持大文件上传,使用application.yml配置失效

这是一个Spring Boot 配置类,用于自定义UndertowWeb 服务器的配置,主要目的是调整请求体(包括文件上传)的最大大小限制

一、类结构说明

1.@Configuration

  • 表明这是一个Spring 配置类,会在应用启动时被加载。
  • 用于定义和注册 Spring Bean。

2.UndertowConfig

  • 自定义 Undertow 服务器配置的配置类。
  • 通常用于替代默认的 Tomcat 配置(如果项目使用的是 Undertow 作为内嵌服务器)。

二、核心配置项

1.MAX_ENTITY_SIZE

  • 定义了一个常量:10L * 1024 * 1024,即10 MB
  • 这是Long 类型,因为 Undertow 的相关选项使用 Long 类型。
  • 该常量被用于两个地方:
    • 普通请求体的最大大小
    • 文件上传请求体的最大大小

三、核心 Bean:undertowCustomizer

1.返回值类型

WebServerFactoryCustomizer<UndertowServletWebServerFactory>
  • 这是一个工厂定制器,允许在 Spring Boot 启动时对 Undertow 服务器进行自定义配置。

2.定制逻辑

  • 使用 Lambda 表达式创建定制器。
  • 通过factory.addBuilderCustomizers添加一个UndertowBuilderCustomizer

四、两个关键配置项

builder中设置了两个 Undertow 选项:

1.UndertowOptions.MAX_ENTITY_SIZE

  • 作用:设置所有普通 HTTP 请求体的最大大小。
  • 默认值:通常是 2 MB。
  • 本次设置:调整为 10 MB。

2.UndertowOptions.MULTIPART_MAX_ENTITY_SIZE

  • 作用:专门用于设置文件上传请求体的最大大小。
  • 默认值:通常是 2 MB。
  • 本次设置:调整为 10 MB。

五、为什么需要这个配置?

1.默认限制较小

  • Spring Boot 默认的请求体限制通常是2 MB
  • 如果上传文件或处理大请求体时超过该限制,会抛出异常。

2.区分普通请求与文件上传

  • MAX_ENTITY_SIZE控制普通 POST/PUT 请求体大小。
  • MULTIPART_MAX_ENTITY_SIZE控制multipart/form-data请求(文件上传)的大小。

3.统一调整为 10 MB

  • 这里将两者统一设置为 10 MB,避免因请求体过大导致的错误。

六、使用场景

  • 当你使用Spring Boot + Undertow作为服务器时。
  • 需要上传大于 2 MB 的文件时。
  • 需要处理较大的 JSON 或 XML 请求体时。

七、注意事项

  1. 仅适用于 Undertow

    • 如果使用 Tomcat 或 Jetty,需要另一种配置方式。
  2. 可能会影响性能

    • 设置过大会增加内存占用,需根据实际需求调整。
  3. 应与前端配置一致

    • 如果前端也有文件上传大小限制,应保持一致。
  4. 可能还需要配置 Spring MVC 的上传限制

    • spring.servlet.multipart.max-file-sizemax-request-size,两者需配合使用。

八、示例扩展

如果还需要设置其他 Undertow 参数,可以在builder中继续添加:

builder.setServerOption(UndertowOptions.MAX_ENTITY_SIZE,MAX_ENTITY_SIZE).setServerOption(UndertowOptions.MULTIPART_MAX_ENTITY_SIZE,MAX_ENTITY_SIZE).setServerOption(UndertowOptions.MAX_PARAMETERS,1000)// 增加最大参数数量.setServerOption(UndertowOptions.MAX_HEADERS,200);// 增加最大请求头数量

这是一个典型的Spring Boot 嵌入式服务器定制配置,用于突破默认请求大小限制,特别适用于需要处理大文件上传或大数据请求的应用场景。

@Configuration public class UndertowConfig{// 配置你需要的最大请求大小,10MB=10*1024*1024 字节(Long类型,匹配UndertowOptions的Long常量) private static final long MAX_ENTITY_SIZE=10L *1024*1024;@Bean public WebServerFactoryCustomizer<UndertowServletWebServerFactory>undertowCustomizer(){return(UndertowServletWebServerFactory factory)->{factory.addBuilderCustomizers((builder)->{// 核心1:设置所有普通请求体最大大小(对应你看到的MAX_ENTITY_SIZE,默认2MB) builder.setServerOption(UndertowOptions.MAX_ENTITY_SIZE, MAX_ENTITY_SIZE)// 核心2:设置文件上传请求体最大大小(对应你看到的MULTIPART_MAX_ENTITY_SIZE,默认2MB) .setServerOption(UndertowOptions.MULTIPART_MAX_ENTITY_SIZE, MAX_ENTITY_SIZE);});};}}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/12 6:20:20

【渗透测试】新手必练的15个靶场,来看下有没有你熟悉的!

前言 相信很多小伙伴们在学习渗透测试的时候&#xff0c;不知道如何开始&#xff0c;那么这下面15个靶场对你的学习将会有很大的帮助&#xff01; 靶场推荐 1、Try Hack Me 官网&#xff1a;https://tryhackme.com/ Try Hack Me是一个在线渗透测试平台&#xff0c;提供丰富…

作者头像 李华
网站建设 2026/4/15 23:28:52

AI 软件的开发流程

AI 软件的开发流程与传统软件开发有着本质的区别&#xff0c;它不再是线性的“需求分析→写代码→测试”&#xff0c;而是一个以数据为中心、不断迭代推理逻辑的循环过程。在 2026 年的标准实践中&#xff0c;一个完整的 AI 应用开发通常遵循以下流程&#xff1a;1. 场景定义与…

作者头像 李华
网站建设 2026/4/16 12:58:48

立春 | 春始冬去 万物生长

立&#xff0c;是破土而出的姿态&#xff1b;春&#xff0c;是时间写给世界的首行情诗。它们相逢&#xff0c;便成了年轮上第一个刻度——不为纪念过往&#xff0c;只为邀你启程。与冬天好好告别&#xff0c;告别那些未化的遗憾&#xff0c;你看冰都在阳光里学会了温柔。春风记…

作者头像 李华
网站建设 2026/4/16 9:52:56

路由策略:企业如何部署本地资源管理、重点业务保障与等级化路由

管理传输资源本地化、部署重点需求策略路由、实施传输需求等级管理 摘要 本文为企业IT部门、信息化负责人及运维团队提供可落地的路由策略标准化方案&#xff0c;通过可视化运行监控系统支撑规划、标准化交付与平台化运维&#xff0c;实现高确定性的ICT基础设施管理&#xff…

作者头像 李华
网站建设 2026/4/15 22:23:56

【小程序毕设全套源码+文档】基于微信小程序django咖啡博物馆预约小程序的设计与实现(丰富项目+远程调试+讲解+定制)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华