0

0

Java接收XML文件 Servlet如何处理multipart/form-data

幻夢星雲

幻夢星雲

发布时间:2026-03-13 11:59:32

|

824人浏览过

|

来源于php中文网

原创

Servlet 3.0+ 应使用 @MultipartConfig 注解配合 request.getPart() 获取 XML 文件,通过 InputStream 读取字节并以 UTF-8 解码为字符串,不可用 getParameter();老版本才需 Apache Commons FileUpload。

java接收xml文件 servlet如何处理multipart/form-data

Servlet接收multipart/form-data中的XML文件,不能用request.getParameter()

XML文件作为二进制附件上传时,它不在表单参数里,而是在 multipart body 的一个 part 中。直接调用 request.getParameter("xmlFile") 一定返回 null —— 这是新手最常踩的坑。

Java Servlet 原生不解析 multipart,必须借助第三方库(如 Apache Commons FileUpload)或使用 Servlet 3.0+ 内置 API。

  • Servlet 3.0+ 推荐用 @MultipartConfig + request.getPart(),无需额外依赖
  • 若项目受限于老版本(如 Servlet 2.5),才需引入 commons-fileuploadcommons-io
  • 注意:Spring MVC 的 @RequestParam MultipartFile 是另一套封装,这里只谈原生 Servlet

@MultipartConfiggetPart()读取XML内容

这是目前最轻量、最可控的方式。关键点在于:Part 对象不是字符串,而是带 headers 的输入流,需手动提取原始字节并转为字符串(注意编码)。

  • Part.getSubmittedFileName() 获取上传的原始文件名(含扩展名)
  • Part.getContentType() 可校验是否为 text/xmlapplication/xml,但不可靠(浏览器可能传错)
  • 务必用 Part.getInputStream() 读取,再用 new String(bytes, StandardCharsets.UTF_8) 解码,避免乱码
  • 不要用 Part.write() 临时写磁盘再读——多一次 I/O,且有权限/路径风险
@WebServlet("/upload")
@MultipartConfig(fileSizeThreshold = 1024 * 1024, maxFileSize = 10 * 1024 * 1024)
public class XmlUploadServlet extends HttpServlet {
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws IOException {
        try {
            Part xmlPart = request.getPart("xmlFile"); // name="xmlFile" 来自 HTML 表单
            String filename = xmlPart.getSubmittedFileName();
            if (!filename.toLowerCase().endsWith(".xml")) {
                response.sendError(HttpServletResponse.SC_BAD_REQUEST, "Only XML files allowed");
                return;
            }
<pre class='brush:php;toolbar:false;'>        InputStream is = xmlPart.getInputStream();
        byte[] bytes = is.readAllBytes(); // Java 9+
        String xmlContent = new String(bytes, StandardCharsets.UTF_8);

        // 此处可交给 DocumentBuilder 或 JAXB 解析
        System.out.println("Received XML length: " + xmlContent.length());

    } catch (ServletException e) {
        response.sendError(HttpServletResponse.SC_BAD_REQUEST, "Invalid multipart request");
    }
}

}

立即学习Java免费学习笔记(深入)”;

PathFinder
PathFinder

AI驱动的销售漏斗分析工具

下载

常见错误:中文文件名乱码、空内容、NullPointerException

这些基本都源于对 multipart 结构理解偏差或编码处理遗漏。

  • getSubmittedFileName() 在 Tomcat 8.5+ 默认 UTF-8,但旧版(如 7.x)需在 server.xmlConnectorURIEncoding="UTF-8",否则中文名变 ???.xml
  • request.getPart("xxx") 返回 null:确认 HTML 表单 <input type="file" name="xxx">name 和后端一致;且表单 enctype 必须是 multipart/form-data
  • 读出来 XML 内容为空:检查是否误调了 xmlPart.getSize() == 0,或流已被其他逻辑提前消费(getInputStream() 只能调一次)
  • 解析时报 org.xml.sax.SAXParseException:大概率是 BOM 头或编码不匹配,建议先用 Files.write(Paths.get("debug.xml"), bytes) 保存本地用编辑器验证

如果必须用Apache Commons FileUpload

仅当无法升级 Servlet 版本时采用。注意它和原生 API 的行为差异:

  • 不再用 request.getPart(),而是用 ServletFileUpload.parseRequest(request) 得到 List<FileItem>
  • FileItem.isFormField() 区分普通字段和文件字段;XML 文件对应的是 !isFormField()
  • FileItem.getString("UTF-8") 可直接获取字符串,但大文件易 OOM;推荐仍用 FileItem.getInputStream()
  • 必须确保 web.xml 没配 <multipart-config>,否则会和 Commons 冲突报错

真正麻烦的从来不是“怎么读到 XML”,而是后续怎么安全地解析它——外部实体、XXE、超深嵌套、超大文本节点……这些得在拿到字符串之后立刻考虑。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
如何配置Tomcat环境变量
如何配置Tomcat环境变量

配置Tomcat环境变量需要在系统中添加CATALINA_HOME变量,并将Tomcat的安装路径添加到PATH变量中。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

117

2023.10.26

idea如何集成Tomcat
idea如何集成Tomcat

idea集成Tomcat的步骤:1、添加Tomcat服务器配置;2、配置项目部署;3、运行Tomcat服务器;4、访问项目;5、注意事项;6、关闭Tomcat服务器。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

173

2024.02.23

怎么查看Tomcat源代码
怎么查看Tomcat源代码

查看Tomcat源代码的步骤:1、下载Tomcat源代码;2、在IDEA中导入Tomcat源代码;3、查看源代码;4、理解Tomcat的工作原理;5、参与社区和贡献;6、注意事项;7、持续学习和更新;8、使用工具和插件。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

99

2024.02.23

常见的tomcat漏洞有哪些
常见的tomcat漏洞有哪些

常见的tomcat漏洞有:1、跨站脚本攻击;2、跨站请求伪造;3、目录遍历漏洞;4、缓冲区溢出漏洞;5、配置漏洞;6、第三方组件漏洞。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

170

2024.02.23

tomcat日志乱码怎么解决
tomcat日志乱码怎么解决

tomcat日志乱码的解决办法:1、修改tomcat的日志编码设置;2、检查ide的编码设置;3、检查操作系统的编码设置;4、使用过滤器处理日志;5、检查外部系统的编码设置;6、检查文件编码方式等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

158

2024.02.23

weblogic和tomcat有哪些区别
weblogic和tomcat有哪些区别

weblogic和tomcat的区别:1、功能;2、性能;3、规模;4、价格;5、安全性;6、配置和管理;7、社区支持;8、集成能力;9、升级和更新;10、可靠性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

200

2024.02.23

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

244

2024.02.23

tomcat启动闪退怎么解决
tomcat启动闪退怎么解决

tomcat启动闪退的解决办法:1、检查java环境;2、检查环境变量配置;3、检查端口被占用;4、检查配置文件编码;5、检查启动时需要的配置文件;6、检查相关文件是否丢失;7、检查防火墙和杀毒软件设置。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

169

2024.02.23

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

37

2026.03.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号