0

0

Node.js接收XML文件 Multer中间件如何配置

星降

星降

发布时间:2026-01-14 20:16:03

|

402人浏览过

|

来源于php中文网

原创

Multer默认不支持XML文件上传,需显式配置fileFilter允许application/xml、text/xml等MIME类型,并使用uploadXml.single('xml')匹配前端name属性,XML内容在req.file.buffer中而非req.body。

node.js接收xml文件 multer中间件如何配置

Node.js中Multer默认不支持XML文件上传

Multer默认只解析 multipart/form-data 类型的请求,且仅对 Content-Typetext/plaintext/csvapplication/json 等常见类型做自动字段解析;XML 文件(application/xmltext/xml)不会被自动解析为 req.body,也不会被 multer().single() 拦截处理——它会被直接忽略或报错 Unexpected field

必须显式配置 fileFilter 允许XML MIME类型

否则 Multer 会拒绝非图片/文档类扩展名的上传。关键点是:XML 文件常以 .xml 结尾,但服务端不能只靠扩展名判断,必须检查 file.mimetype

  • fileFilter 函数必须返回 true 才允许该文件进入内存或磁盘
  • 常见合法 XML MIME 类型包括:application/xmltext/xmlapplication/x-xml
  • 不要只校验 path.extname(file.originalname) === '.xml'浏览器可能不带扩展名或伪造
const multer = require('multer');

const xmlStorage = multer.memoryStorage(); // 推荐用 memoryStorage,便于后续解析字符串

const uploadXml = multer({ storage: xmlStorage, fileFilter: (req, file, cb) => { if ( file.mimetype === 'application/xml' || file.mimetype === 'text/xml' || file.mimetype === 'application/x-xml' ) { cb(null, true); } else { cb(new Error('Only XML files are allowed')); } }, limits: { fileSize: 5 1024 1024 // 限制5MB以内,防爆内存 } });

使用 uploadXml.single('xml') 时字段名必须匹配前端

XML 文件在表单中通常作为单个文件上传,后端需指定字段名(如 xml),与前端 HTML 的 name 属性一致。若不一致,Multer 会报 Unexpected field 错误。

易森网络企业版
易森网络企业版

如果您是新用户,请直接将本程序的所有文件上传在任一文件夹下,Rewrite 目录下放置了伪静态规则和筛选器,可将规则添加进IIS,即可正常使用,不用进行任何设置;(可修改图片等)默认的管理员用户名、密码和验证码都是:yeesen系统默认关闭,请上传后登陆后台点击“核心管理”里操作如下:进入“配置管理”中的&ld

下载
  • 前端示例:
  • 后端路由中必须用 uploadXml.single('xml'),不是 'file''data'
  • 成功后,文件内容在 req.file.buffermemoryStorage 下)或 req.file.pathdiskStorage 下)
  • 记得用 xml2jsfast-xml-parser 等库进一步解析 req.file.buffer.toString()

注意 req.body 里不会有XML内容,所有数据都在 req.file

Multer 不会把 XML 文件内容塞进 req.body,哪怕你用 uploadXml.none() 也不行——它只处理 multipart 中的文件部分。如果前端还提交了其他表单字段(如 ),它们会出现在 req.body.id,但 XML 本身只在 req.file

  • 别写 console.log(req.body) 期待看到 XML 字符串
  • 正确读取方式:const xmlStr = req.file.buffer.toString('utf8');
  • 若用 diskStorage,需先 fs.readFileSync(req.file.path, 'utf8')
  • 务必校验 req.file 是否存在,避免 Cannot read property 'buffer' of undefined

XML 解析逻辑和错误处理容易被跳过,尤其当上传大文件或格式非法时,req.file.buffer 可能为空或乱码——建议在调用 fast-xml-parser.parse() 前加 try/catch 并检查 req.file.buffer.length

相关专题

更多
什么是中间件
什么是中间件

中间件是一种软件组件,充当不兼容组件之间的桥梁,提供额外服务,例如集成异构系统、提供常用服务、提高应用程序性能,以及简化应用程序开发。想了解更多中间件的相关内容,可以阅读本专题下面的文章。

177

2024.05.11

Golang 中间件开发与微服务架构
Golang 中间件开发与微服务架构

本专题系统讲解 Golang 在微服务架构中的中间件开发,包括日志处理、限流与熔断、认证与授权、服务监控、API 网关设计等常见中间件功能的实现。通过实战项目,帮助开发者理解如何使用 Go 编写高效、可扩展的中间件组件,并在微服务环境中进行灵活部署与管理。

212

2025.12.18

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

411

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

532

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

309

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

html版权符号
html版权符号

html版权符号是“©”,可以在html源文件中直接输入或者从word中复制粘贴过来,php中文网还为大家带来html的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

608

2023.06.14

html在线编辑器
html在线编辑器

html在线编辑器是用于在线编辑的工具,编辑的内容是基于HTML的文档。它经常被应用于留言板留言、论坛发贴、Blog编写日志或等需要用户输入普通HTML的地方,是Web应用的常用模块之一。php中文网为大家带来了html在线编辑器的相关教程、以及相关文章等内容,供大家免费下载使用。

646

2023.06.21

Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

36

2026.01.14

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

AngularJS教程
AngularJS教程

共24课时 | 2.6万人学习

CSS教程
CSS教程

共754课时 | 19万人学习

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

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