我正在编写一个spring rest方法,以从数据库中获取详细信息,并将其设置在响应POJO中,然后将其返回.当前,当使用POSTMAN或RC(例如带有数据的可下载CSV文件)命中URL时,我需要以CSV而不是默认json的形式生成此响应.我用Google搜索了许多网站,但不确定其中的逻辑.
>我们是否需要编写业务逻辑以将pojo类值转换为csv格式,或者spring是否具有任何转换机制?
> Produces =“ text / csv”在很多地方都被提及,这是否正确转换了响应?
目前,我尚未为CSV转换编写任何代码.
@GetMapping("/batch/export" , produces="text/csv")
public ResponseEntity getBatchDetails(
HttpServletRequest request) {
ApplicationRequest appRequest = ApplicationServiceMapper.mapRequestFromHttpRequest(request);
ApplicationResponse response = appService.getDBDetails(appRequest);
return new ResponseEntity<>(response, HttpStatus.OK);
}
这里的响应是服务以其pojo格式返回的所有数据的响应,如果我们不给注解中的产生,那么默认情况下spring将返回响应json.有人可以指导我吗?提前致谢.
解决方法:
仅将@GetMapping与producer =“ text / csv”结合使用是不够的.它仅负责设置响应头Content-Type:text / csv.
您需要将响应添加为参数HttpServletResponse响应,将POJO转换为有效的csv文件,然后将csv文件写入HttpServletResponse.
标签:spring-boot,csv,spring-restcontroller,spring,java
来源: https://codeday.me/bug/20191111/2017053.html