spring 导出csv文件_java-使用Spring Boot生成CSV文件的GetMapping

我正在编写一个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


版权声明:本文为weixin_39747755原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。