XSSFWorkbook对象 进行zip打包时 用write资源流…

2019-08-16 12:30:47来源:博客园 阅读 ()

新老客户大回馈,云服务器低至5折

XSSFWorkbook对象 进行zip打包时 用write资源流自动关闭处理办法

XSSFWorkbook对象的write方法内会将传入的资源流自动关闭 导致下载excel失败

错误代码

    OutputStream out = response.getOutputStream(); 
    ZipOutputStream zos = new ZipOutputStream(out);
    XSSFWorkbook workbook = new XSSFWorkbook();
    // 将文件写入zip内,即将文件进行打包
    zos.putNextEntry(new ZipEntry(fileName + "(" + UUID.randomUUID() + ")." + typeName));

    // 此处将自动关闭zos资源
    workbook.wirte(zos);

解决方法: 将XSSFWorkbook转换成ByteArrayOutputStream,用ByteArrayOutputStream对象将流写入zip对象中

    OutputStream out = response.getOutputStream(); 
    ZipOutputStream zos = new ZipOutputStream(out);
    XSSFWorkbook workbook = new XSSFWorkbook();
    // 将文件写入zip内,即将文件进行打包
    zos.putNextEntry(new ZipEntry(fileName + "(" + UUID.randomUUID() + ")." + typeName));
    ByteArrayOutputStream bos = new ByteArrayOutputStream();
    workbook.write(bos);
    bos.writeTo(zos);
    zos.closeEntry();

    // 当所有文件打包完成后关闭zos资源
    zos.close();

原文链接:https://www.cnblogs.com/bradcai/p/11344247.html
如有疑问请与原作者联系

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:Windows下载安装RabbitMQ教程

下一篇:一文搞明白位运算、补码、反码、原码