vue3上传多个文件并携带参数一起上传,后台java接收

article/2025/6/21 1:22:49

直接上代码

vue代码 上传文件组件,采用element-plus

<el-uploadref="upload"class="upload-files"action=""name="files"multiple:auto-upload="false":file-list="fileList":on-change="handleChange"style="margin-top: 20px"><el-button slot="trigger" type="primary">选取文件</el-button></el-upload><div slot="footer" class="dialog-footer"><el-button type="primary" @click="submitUpload">保存</el-button></div>

这里采用的是手动上传,选取文件后,点击保存才会触发上传操作

script 代码
// 上传文件数组
const fileList = ref([]) // 文件改变时回调钩子
const handleChange = (file, files) => {// file是当前上传的文件,files是当前所有的文件,// 不懂得话可以打印一下这两个数据 就能明白fileList.value = files
}// 测试多文件上传
const submitUpload = async () => {let formData = new FormData()formData.append('name', 'myk')fileList.value.forEach(item => {// 这里有个坑,在将文件append到formData的时候, item其实并不是真是数据 item.raw才是formData.append('files', item.raw)})// 这里是发送请求,注意 headers: {'Content-Type': 'multipart/form-data'}let result = await requestUtil.fileUpload('/testUpload', formData)console.log(result)
}

这个地方如果不添加.raw  可以看到这个files是个[object Object] 同样它传入后台是个String类型

你用MultipartFile[]来接收这个String类型的 “[object Object]” 这肯定不行啊

就会给你报一个错 Field error in object 'testUploadVo' on field 'files': rejected value [[object Object]]

 我们再来试试加上.raw 可以看到这是files字段是个二进制,请求也发送成功了

 看一下后台打印

 确实可以接收到文件了,那试试多个文件

 多个文件也是可以接收到

现在来看看后台代码

创建一个实体类来接收参数

package com.mayk.controller;import lombok.Data;
import org.springframework.web.multipart.MultipartFile;/*** @author: mayk* @date: 2023/4/13*/
@Data
public class TestUploadVo {private String name;private MultipartFile[] files;
}

在创建一个controller

package com.mayk.controller;import org.springframework.web.bind.annotation.CrossOrigin;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;/*** @author: mayk* @date: 2023/4/13*/
@RestController
@CrossOrigin
public class TestUpload {@PostMapping("/testUpload")public String testUpload(TestUploadVo testUploadVo) {for (MultipartFile file : testUploadVo.getFiles()) {System.out.println(file.getOriginalFilename());}System.out.println(testUploadVo.getName());return "ok";}
}

不需要添加@requestBody 因为这是前端是采用的FromData提交的

这样一个手动上传多文件就完成了

欢迎大佬指点


http://chatgpt.dhexx.cn/article/fGBDcmqu.shtml

相关文章

vue前端实现上传文件,vue 上传文件

以ASP.NET Core WebAPI 作后端 API &#xff0c;用 Vue 构建前端页面&#xff0c;用 Axios 从前端访问后端 API ,包括文件的上传和下载。 准备文件上传的API #region 文件上传 可以带参数 [HttpPost("upload")] public JsonResult uploadProject(IFormFile file, st…

通过elementui-vue上传文件到本地服务器

目录 1.文件上传原理 2.文件上传到本地服务器 3.elementuivueaxios完成文件上传 4.上传到oss阿里云的服务器 4.1申请oss文件服务 4.2在oss界面上操作文件上传 4.3申请阿里云的密钥 1.文件上传原理 2.文件上传到本地服务器 (1)引入文件上传的依赖 <dependency><…

vue上传文件夹的解决方案

一、 功能性需求与非功能性需求 要求操作便利&#xff0c;一次选择多个文件和文件夹进行上传&#xff1b; 支持PC端全平台操作系统&#xff0c;Windows,Linux,Mac 支持文件和文件夹的批量下载&#xff0c;断点续传。刷新页面后继续传输。关闭浏览器后保留进度信息。 支持文件…

1、【Vue上传文件】当接口Content-Type为multipart/form-data时,如何上传文件到后端

<input type"file" id"putfile" ref"inputer" change"fileUpload" /> //方法&#xff1a; fileUpload(event) {console.log(event);let file event.target.files;//一个文件流let formData new FormData();formData.append(&q…

SpringBoot+Vue上传文件

最近在研究SpringBootVue的文件上传&#xff0c;踩了不少坑。现在将正确的文件上传流程分享一下。 一、前端采用ElementUI组件 前端页面完整代码&#xff1a; <template><el-uploadclass"upload-demo"action"http://localhost:1111/01/fileup"…

vue如何优雅的上传文件

vue如何优雅的上传文件 上传文件的方式1.表单提交文件2.Elementui封装的组件提交文件 上传文件的方式 下面是我使用过得两种提交方式&#xff0c;就详细说一下哈 1.表单提交文件 2.Elementui封装的组件提交文件 1.表单提交文件 html页面&#xff1a; 为了页面美观&#xff…

vue实现文件上传

记录问题&#xff0c;方便回顾 1、使用elementUI的 el-upload插件进行上传。 2、使用input。 1、使用elementUI的 el-upload插件进行上传。 html: <el-uploadref"avatar-uploader"class"avatar-uploader":show-file-list"false":auto-uploa…

Vue实现多文件上传

一、需求说明及展示 通过vue和element实现多文件上传 二、实现步骤 // 代码片<el-formref"dataForm"v-loading"formLoading":model"temp":inline"true"size"mini"label-position"right"label-width"8…

vue 实现文件上传

&#xff08;一&#xff09;首先实现html、css布局 代码&#xff1a; <template><div class"image-uploader"><img :src"uploadIcon" class"icon"/> <p>Drag your images here</p><p>OR</p><div …

vue文件上传和下载

文件上传 这里使用elementui组件库的文件上传组件 1.手动上传&#xff08;文件选取后需点击确认上传&#xff09; action&#xff1a;上传地址auto-upload&#xff1a;是否在选取文件后立即进行上传&#xff0c;默认true手动上传要将其设置为falsebefore-upload &#xff1a…

windows修改文件后缀名(文件扩展名)

1.直接修改 打开我的电脑->查看->文件拓展名 勾上即可 before \qquad\qquad\qquad\qquad\qquad after \qquad\qquad 2.任何文本编辑器->另存为->保存类型选所有文件

Windows11修改文件后缀名的方法

Windows11修改文件后缀名的方法 最近买了一台新电脑&#xff1a;suface pro8 新电脑是真的香啊&#xff0c;但是目前发现一个问题&#xff0c;就是windows11的环境对文件后缀名的可修改性不太友好。 他的自定义是对文件后缀名也看不见的&#xff0c;通过一些设置可以查看到文件…

window10 系统下如何修改文件后缀

文章目录 需求&#xff1a;修改后缀&#xff08;方法一&#xff09;&#xff1a;1、打开-- 文件扩展名&#xff1a;2、重名了文件&#xff1a; 修改后缀&#xff08;方法二&#xff0c;新增&#xff09;1、代码修改过程&#xff08;很简单&#xff0c;拖入&#xff0c;写入文件…

matlab 实现批量修改文件后缀名 案例

实现目标描述&#xff1a;选择我有一个大文件&#xff0c;里面有许多子文件夹&#xff0c;子文件夹内都是csv格式的文件&#xff0c;我现在将这个大文件内所有子文件夹的.csv文件的后缀名改为.sps文件 %author foddcus FAFU %用法&#xff1a;批量修改文件后缀名 clear all src…

如何修改文件后缀

文章目录 1.搜索“文件资源管理器选项”2.打开我的电脑选项 1.搜索“文件资源管理器选项” 点击查看、取消选择“隐藏拓展名”2.打开我的电脑选项 wine打开文件夹资源管理器&#xff0c;点击查看&#xff0c;点击“文件拓展名”

WIN10 如何修改 文件后缀名 设置后缀名可修改

管理员权限下&#xff1a;打开任意一个文件夹---查看---选中文件扩展名&#xff1a;这时 文件的后缀名就显示出来了&#xff0c;单击文件 就可以修改后缀名了

python文件操作3--批量修改文件后缀名

1、引言 需要把.dat 格式 转化成 .txt格式 2、实现 # python批量更换后缀名 import os# 列出当前目录下所有的文件 files os.listdir(.) for filename in files:portion os.path.splitext(filename)# 如果后缀是.datif portion[1] ".dat": # 重新组合文件名和…

怎么修改html后缀名,在win7系统下如何修改文件后缀名?win7修改文件后缀名html方法...

在win7系统默认情况下&#xff0c;直接在文件后面加上“.扩展名”&#xff0c;相当于给文件命名&#xff0c;而不是直接修改文件类型的。那么在win7系统下如何修改文件后缀名?下面小编就为大家介绍win7修改文件后缀名html方法&#xff0c;一起来看看吧&#xff01; 方法/步骤 …

linux 批量修改文件后缀名

今天遇到的一个问题&#xff0c;要将一批jpg文件后缀名更改为png&#xff0c;凭感觉能用awk指令进行修改&#xff0c;就进行了尝试。 想到的思路是&#xff1a;先列举出文件名称&#xff0c;再用awk对文件名称进行处理分割&#xff0c;最后将后缀名进行修改。 首先列举出文件…

批量修改后缀名的方法,批量修改文件后缀名

批量修改后缀名的方法&#xff0c;批量修改文件后缀名&#xff01;文件的后缀名就是文件的拓展名&#xff0c;有些小伙伴在工作中经常需要修改文件后缀名&#xff0c;这是一个并不困难的电脑操作&#xff0c;我们只需要选中文件然后鼠标右击它&#xff0c;点击重命名&#xff0…