0

0

React上传XML文件 Ant Design的upload组件如何自定义请求

煙雲

煙雲

发布时间:2026-01-28 10:42:10

|

688人浏览过

|

来源于php中文网

原创

Ant Design Upload 组件默认使用 XMLHttpRequest 且不走 axios/fetch,必须通过 customRequest 手动实现上传逻辑以支持 Authorization、timeout、onUploadProgress 及 application/xml 类型;需直接传 file 对象而非 FormData,并注意编码、响应类型与组件卸载防护。

react上传xml文件 ant design的upload组件如何自定义请求

Ant Design Upload 组件默认不走 axiosfetch,而是用原生 XMLHttpRequest

这是关键前提:即使你项目里全局用了 axiosUploadcustomRequest 不显式覆盖,它就自己发请求,且无法携带 Authorization 头、无法设 timeout、无法监听 onUploadProgress —— 更别说上传 XML 文件时需要指定 Content-Type: application/xml

必须用 customRequest 替换默认上传逻辑

XML 文件本质是二进制 Blob,但服务端通常要求明确的 Content-Type 和原始文本结构。直接传 file 对象给 FormData 会自动加 boundary,不适合纯 XML 场景。

  • customRequest 函数接收 { file, onSuccess, onError, onProgress } 四个参数,必须手动调用它们来控制状态
  • 不要用 FormData.append('file', file) —— 这会让服务端收到 multipart 包裹体,而多数 XML 接口期望裸 XML 字符串或原始字节
  • 推荐读取为 text 后用 Blob 构造新对象,或直接用 file(如果服务端接受原始 application/xml
  • onProgress 只在 XMLHttpRequest.upload 上可用,fetch 原生不支持上传进度,所以这里仍建议用 XMLHttpRequest
customRequest: ({ file, onSuccess, onError, onProgress }) => {
  const xhr = new XMLHttpRequest();

xhr.upload.onprogress = (e) => { if (e.lengthComputable) { onProgress({ percent: (e.loaded / e.total) * 100 }); } };

xhr.onload = () => { if (xhr.status >= 200 && xhr.status < 300) { onSuccess(xhr.response); } else { onError(new Error(Upload failed: ${xhr.status} ${xhr.statusText})); } };

xhr.onerror = () => onError(new Error('Network error'));

xhr.open('POST', '/api/upload-xml'); xhr.setRequestHeader('Content-Type', 'application/xml'); // 如果需要鉴权 // xhr.setRequestHeader('Authorization', Bearer ${token});

xhr.send(file); }

XML 文件内容校验和编码问题要提前处理

浏览器读取 XML 文件时,file.text() 会按 UTF-8 解码;但如果文件含 BOM 或声明了 ,直接上传可能被服务端拒绝。稳妥做法是跳过解析,原样上传字节流 —— 这正是 xhr.send(file) 的优势。

PageGen
PageGen

AI页面生成器,支持通过文本、图像、文件和URL一键生成网页。

下载
  • 避免先 file.text().then(str => new Blob([str], ...)),这会二次编码,可能破坏原始声明
  • 若必须预览或校验内容,用 new FileReader().readAsText(file, 'UTF-8') 并捕获异常,但上传仍用原始 file 对象
  • 后端若返回非 JSON 响应(比如纯 XML 成功响应),注意 xhr.responseType 设置(如 'document'''),否则 xhr.response 可能为空

React 18 下注意 customRequest 的异步稳定性

如果上传中组件卸载,onSuccessonError 调用时可能触发 “Cannot update a component while rendering” 报错。需加简单清理机制:

  • customRequest 内部声明一个 isMounted = truexhr.onload 前判断
  • 或用 useRef 存储挂载状态,在 useEffect(() => () => { isMounted.current = false }, [])
  • 更轻量的做法:只确保 onSuccess/onError 是函数再调用,Ant Design 内部已做基础防护,但业务侧状态更新仍需自行守卫

XML 上传真正麻烦的不是格式本身,而是服务端对 Content-Type、编码、响应体类型的隐式约定 —— 动手前先 curl -v -H "Content-Type: application/xml" --data-binary @test.xml 验证通路,比调半天 React 逻辑更省时间。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
json数据格式
json数据格式

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

418

2023.08.07

json是什么
json是什么

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

535

2023.08.23

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

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

311

2023.10.13

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

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

77

2025.09.10

while的用法
while的用法

while的用法是“while 条件: 代码块”,条件是一个表达式,当条件为真时,执行代码块,然后再次判断条件是否为真,如果为真则继续执行代码块,直到条件为假为止。本专题为大家提供while相关的文章、下载、课程内容,供大家免费下载体验。

94

2023.09.25

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1899

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2091

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1063

2024.11.28

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

84

2026.01.28

热门下载

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

精品课程

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

共58课时 | 4.2万人学习

国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 1.0万人学习

React核心原理新老生命周期精讲
React核心原理新老生命周期精讲

共12课时 | 1万人学习

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

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