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 稳定得多。
相关推荐
梦幻通灵9 分钟前
Vue3 Element日期控件置灰明天之后日期
前端·javascript·vue.js
lzhdim10 分钟前
C盘空间多出来4GB:谷歌服软 Chrome本地AI大模型可禁用、删除了
前端·人工智能·chrome
Monkery11 分钟前
WWDC26 全面汇总
前端·人工智能
ANnianStriver26 分钟前
PetLumina 03 — 后端目录重构与 Web 管理后台搭建
java·前端·ai·重构·ai编程·claude code
晓131329 分钟前
【Cocos Creator 3.x】篇——第一章 简介
前端·javascript·游戏引擎
light blue bird29 分钟前
MES/ERP 协同场景导入导出图表展示组件
前端·信息可视化·桌面端winform·多节点端·gdi图表绘制开发
周杰伦fans1 小时前
AutoCAD2016经典模式不见了-设置回14版本前的经典工作空间
服务器·c语言·前端
Front思1 小时前
shopify前端开发
前端
风骏时光牛马1 小时前
Julia常见问题汇总与代码示例
前端