需求
今天有个常规的需求,先上传一个文件,然后解析文件填充些属性在下载下来,但是最后使用swagger测试的时候,发现下载的文件打开失败,说文件格式不匹配或者文件内容损坏。
通过搜索发现需要在api上面加入这个
@ApiOperation(value="测试",produces="application/octet-stream")
@RequestMapping 里面也有produces 和consumes,
produces ==> 指定返回值类型,不但可以设置返回值类型还可以设定返回值的字符编码
consumes ==> 指定处理请求的提交内容类型(Content-Type),例如application/json, text/html;
加了上面得到注解后,对于那种查询一些数据,然后导出到excel 进行下载是可以正常打开的。但是我的这种上传文件再下载的场景还是打不开。想了各种方法,发现如果不传MultipartFile file 这个参数,文件就可以正常打开,传了这个参数文件就打不开了。并且下载下来的文件大小变大了。
最后考虑是swagger的问题,用postman请求同样的api, 发现文件可以正常的上传和下载。 应该是swagger对于这种情况作了特殊处理,导致下载的文件被损害了。