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 稳定得多。
相关推荐
老王以为18 小时前
React Renderer 分离的多平台架构
前端·react native·react.js
hunterandroid18 小时前
Kotlin Coroutines 与 Flow:让异步任务更清晰
前端
Bigger18 小时前
从零搭建 AI 代码审查服务:一份前端也能看懂的 Python 学习笔记
前端·ci/cd·ai编程
lichenyang45319 小时前
JSAPI、NAPI、Biz、Imp:ASCF Demo 如何真正调用系统能力和 C++ 能力
前端
lichenyang45319 小时前
IPC、JSVM、UIThread、libuv:ASCF 架构图里最容易混的几个词
前端
用户0595401744619 小时前
Redis记忆存储故障恢复测试踩坑实录:手动测试让我漏掉了2个一致性Bug
前端·css
用户21366100357219 小时前
Vue2脚手架工程化与Axios集成
前端·vue.js
我不是外星人19 小时前
我把 Claude Code 搬到网页!自研高颜值 Web 交互工作台
前端·ai编程·claude
mixuecoding19 小时前
零成本搭建全球科技热点情报站:12 个平台,6 小时,0 元
前端
用户0595401744619 小时前
用了3年Mock,才发现Redis记忆存储的测试一直漏掉了60%的边界场景
前端·css