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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值