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

1
2
3
4
5
6
7
8
9
10 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 }
下面是报错相关代码
1 2 3 4 5 | @PostMapping("/batchByExcel") public BaseResponse createBatchOrders(@ApiParam("上传文件") @RequestParam("fileName") MultipartFile file, @Valid @RequestBody CreateBatchOrderReq req) { //codes... } |
-------------------------
解决方法是,将上面的一个接口拆分成两个:
一个接收文件,保存文件到本地或者其他服务器,返回一个文件编码或者文件地址;
一个接口接收json数据,json参数中包含文件编码或者地址,根据编码或地址找到文件进行后续的数据操作。
1 2 3 4 5 6 7 8 9 10 11 12 | @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) :

