uniapp上传文件的载荷是个空对象

官方文件上传

原因:

uniapp上传文件的时候不能用 new FormData 上传,必须用 uni.uploadFile,是因为跨端环境不统一、没有 DOM、没有原生 File/FormData 对象。

一、各端根本差异(最关键)

1)小程序 / App(iOS/Android)
  • 没有浏览器 DOM :没有 window、没有 FormData、没有 File、没有 <input type="file">
  • 你拿不到浏览器里的 file 对象,自然没法 new FormData().append('file', ...)
  • 只能通过 uni 提供的 API 选文件:
    • uni.chooseImage
    • uni.chooseFile 返回的是临时路径字符串 (如 wxfile://..._www/...),不是 File 对象。
2)H5 端(浏览器)
  • 虽然浏览器有 FormData,但 uni.uploadFile 不接受原生 FormData 作为参数
  • uni.uploadFile 的 formData 只接受普通 JS 对象 (key-value),内部会帮你组装成正确的 multipart/form-data 请求。
  • 如果你在 H5 自己 new FormData 然后用 uni.request 发:
    • 容易边界(boundary)错误
    • Content-Type 写错
    • 二进制文件损坏
    • 后端收不到文件。

二、uni.uploadFile 做了什么(为什么必须用它)

它是 uni-app 跨端统一的文件上传专用 API

  1. 自动处理 multipart/form-data
    • 自动设置正确 Content-Type
    • 自动生成合法 boundary
    • 自动把文件流和表单字段打包。
  2. 统一路径处理
    • 小程序:wxfile://
    • App:本地绝对路径
    • H5:转成浏览器 File/Blob 你只需要传 filePath 字符串,不用管各端差异。
  3. 底层走平台原生能力
    • 小程序:底层调用 wx.uploadFile
    • App:原生网络库上传
    • 比自己用 uni.request + FormData 稳定得多。
相关推荐
yuhaiqiang4 小时前
当程序员被ai逼到了悬崖边,还有哪些选择?
前端·人工智能·后端
D_jing206 小时前
Vue 3 + Element Plus 重置el-drawer样式失效
前端·javascript·vue.js
__log6 小时前
Vue 3 与 React 18+ 核心技术深度对比:从源码到实战
前端·vue.js·react.js
很晚很晚了11 小时前
纯前端转全栈 Day 1:我从第一个 NestJS 接口开始
前端
Lee川12 小时前
从零解剖一个 AI Agent Tool是如何实现的
前端·人工智能·后端
wangruofeng13 小时前
Playwright 深度调研:为什么它成了浏览器自动化的新底座
前端·测试
李白的天不白15 小时前
SSR服务端渲染
前端
卷帘依旧16 小时前
SSE(Server-Sent Events)完全指南
前端
码云之上16 小时前
万星入坞:我们如何用三层插件体系干掉巨石应用
前端·架构·前端框架