说下场景吧,前端一个订单表单,填好相应的表单信息封装成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/questions/695481) :

  

 

 

 

 

 

更多推荐

Content type 'multipart/form-data;boundary=.. WebKitFormBoundary..;charset=