Content type 'multipart/form-data;boundary=.. WebKitFormBoundary..;charset=UTF-8' not supported

本文探讨了在前端表单中同时上传JSON数据和Excel文件的挑战,详细解释了为何使用Content-Type: multipart/form-data会导致JSON数据解析失败。提供了一种解决方案,即将上传过程分为两步:首先上传文件并获取文件标识,然后在第二个接口调用中携带该标识及JSON数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 说下场景吧,前端一个订单表单,填好相应的表单信息封装成json数据上传,并且附带上传一个Excel文件,同一个接口提交到后端,想着后端代码通过实体接收json数据,然后解析接收到的excel文件,然而   这么基础的http请求头类型的问题坑了自己(对象实体和文件是不同类型的数据,同一个接口提交,用Content-Type: multipart/form-data是解析不了我的json参数的)

请求体

curl -X POST --header 'Content-Type: multipart/form-data' --header 'Accept: application/json' -d '{
  "customerId": "CU43531977852501",
  "endTime": "2020-04-04 16:53:34",
  "flowStrategy": "",
  "orderName": "测试1",
  "pdCode": "1111111",
  "sourceUrls": [],
  "startTime": "2020-04-03 16:53:34",
  "targetUrl": ""
}' 'http://localhost:8081/order/batchByExcel'

返回响应数据 

{ "code": "PARAM_WRONG", "msg": "Content type 'multipart/form-data;boundary=----WebKitFormBoundaryW25LVTHs8WCBZUfG;charset=UTF-8' not supported", "dataObject": null }

下面是报错相关代码 

@PostMapping("/batchByExcel")
public BaseResponse createBatchOrders(@ApiParam("上传文件") @RequestParam("fileName") MultipartFile file,
                                      @Valid @RequestBody CreateBatchOrderReq req) {
    //codes...
}

-------------------------

解决方法是,将上面的一个接口拆分成两个:

一个接收文件,保存文件到本地或者其他服务器,返回一个文件编码或者文件地址;

一个接口接收json数据,json参数中包含文件编码或者地址,根据编码或地址找到文件进行后续的数据操作。


@PostMapping("/batchFile")
public BaseResponse uploadBatchFile(@ApiParam("上传文件") @RequestParam("fileName") MultipartFile file) {
    //codes...
}



@PostMapping("/batch")
@ApiOperation(value = "新增批量订单(需要先导入excel)")
public BaseResponse createBatchOrders(@Valid @RequestBody CreateBatchOrderReq req) {
        //codes...
}

 

-------------------------

原因(引用自https://ask.csdn.net/questions/695481) :

  

 

 

 

 

 

评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值