说下场景吧,前端一个订单表单,填好相应的表单信息封装成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=
发布评论