easyexcel结合feign,文件如何导出的问题

问题描述:直接调用policy服务的导出接口可以正常导出。admin服务调用policy服务导出接口文件无法导出。
!!!!结论:policy服务导出后不能提前关闭流,feign调用后需要将响应体转换
解决方案:

-admin接口以及响应体转换方法。因为使用了feign,导致响应体结构变化,需要从里面拿到输入输出流

@ApiOperation("计划定制-导入计划")
@PostMapping("/importPlan")
public void importPlan(@RequestPart("file") MultipartFile file, HttpServletResponse response) {
    try {
        Response resp = marketingFeign.importPlan(file);
        response.setContentType(resp.headers().get("content-type").toString());
        if(!resp.headers().get("content-type").toString().contains("application/json")){
            feignResp2ServletResp(resp,response);
        }
    } catch (IOException e) {
        log.info("导入计划异常",e);
    }
}
//将feignResponse转为HttpServletResponse
public void feignResp2ServletResp(Response feignResponse, HttpServletResponse response) throws IOException {
    Response.Body body = feignResponse.body();
    try (InputStream inputStream = body.asInputStream(); OutputStream outputStream = response.getOutputStream())
    {
        response.setHeader(HttpHeaders.CONTENT_DISPOSITION, feignResponse.headers().get(HttpHeaders.CONTENT_DISPOSITION).stream().findFirst().get());
        response.setContentType(feignResponse.headers().get(HttpHeaders.CONTENT_TYPE).stream().findFirst().get());
        IOUtils.copy(inputStream, outputStream);
    }
}
  • feign方法:注意 如果是多个请求参数,也需要在前面加上@RequestPart,否则编译不通过
 - `    @PostMapping(value = "/planconfig/importPlan",consumes = MediaType.MULTIPART_FORM_DATA_VALUE)
    Response importPlan(@RequestPart("file") MultipartFile file);`
  • 导出:重点!!!创建excelWriter时需要指定).autoCloseStream(false)属性,使其写入完成后不关闭。
  • 多sheet页填充
 - ` try (OutputStream out = response.getOutputStream()){
                        response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
                        response.setCharacterEncoding("utf-8");
                        String fileName = URLEncoder.encode("计划导入失败结果", "UTF-8").replaceAll("\\+", "%20");
                        response.setHeader("Content-disposition", "attachment;filename*=utf-8''" + fileName + ".xlsx");
                        ExcelWriter excelWriter = EasyExcel.write(out).autoCloseStream(false).build();

                        WriteSheet writeSheet = EasyExcel.writerSheet(0, "计划信息").head(LdContPlanDto.class).build();
                        excelWriter.write(planDtoList, writeSheet);
                        WriteSheet writeSheet1 = EasyExcel.writerSheet(1, "责任信息").head(LdContPlanDetailDto.class).build();
                        excelWriter.write(detailDtoList, writeSheet1);
                        excelWriter.finish();
                    } catch (Exception e) {
                        // 重置response
                        response.reset();
                        response.setContentType("application/json");
                        response.setCharacterEncoding("utf-8");
                        Map<String, String> map = MapUtils.newHashMap();
                        map.put("status", "failure");
                        map.put("message", "下载文件失败" + e.getMessage());
                        response.getWriter().println(JSONObject.toJSONString(map));
                    }`

单sheet页

EasyExcel.write(response.getOutputStream(), LcContTemplateDto.class).autoCloseStream(false).sheet("个单导入结果")
                            .doWrite(errorList);
  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值