背景:controller 接口开始设计的时候没有上传文件的需求,所以请求参数使用 @RequestBody @Validated 注解
需求:需要在接口上加入文件上传功能
分析
问:接口需要上传文件时,能不能使用 @RequestBody 注解
答:不能,因为使用 @RequestBody 注解时,Content-Type 的值为 application/json,而文件上传时 Content-Type 的值为 multipart/form-data
如何修改
- 删除 @RequestBody 注解,@Validated 继续保留
@ApiOperation(value = "新增项目", notes = "新增项目")
@PostMapping(value = "/xxx")
ResponseEntity<xxx> xxx(@Validated ReqDTO req) throws Exception {
...;
return xxx;
}
- 请求参数类 ReqDTO 添加文件列表 List annexs
@Data
@ApiModel(value = "ReqDTO ", description = "请求体")
public class ReqDTO {
@ApiModelProperty("附件")
List<MultipartFile> annexs;
}
注意:判断文件列表 annexs 是否为空不能用 CollectionUtils.isEmpty(),可以使用 Optional.ofNullable().isPresent() 判断
postman 如何调用