JAVA使用upload上传文件并带参数传给后端charset=UTF-8 not supported异常

Vue、Element、JAVA下使用upload上传文件并带参数传给后端

  <el-upload 
           	 class="upload-demo"
             :action="uploadUrl+'/fly/uavAsset/upload'"
             :data="groupId"
             :show-file-list="false"
             :headers="headers"
             :on-success="onSuccess"
             :before-upload="beforeAvatarUpload">

	带入参数groupID,请求参数的格式如下为

在这里插入图片描述
此时后端如果使用@RequestBody接收会报出
org.springframework.web.HttpMediaTypeNotSupportedException: Content type ‘multipart/form-data;boundary=----WebKitFormBoundarywY7ByvgonAjDoaCT;charset=UTF-8’ not supported

@RequestBody表示将JSON或XML数据与DTO bean映射一起使用。如果是MultipartFile,则不能使用JSON数据,因此不能使用@RequestBody。应该使用@ModelAttribute如下

public ExcelResult uploadExcel(@ModelAttribute UploadDto uploadDto) {}

@Data
public class UploadDto {

    private MultipartFile file;

    private Integer groupId;
}

这样就后端就能够接收到MultipartFile 和 json 参数啦


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值