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();
本文介绍了一种使用XSSFWorkbook导出Excel时遇到的问题及解决方案。错误在于XSSFWorkbook的write方法会自动关闭输出流,导致无法正确打包到Zip文件中。通过将XSSFWorkbook的内容转换为ByteArrayOutputStream再写入ZipOutputStream的方法成功解决了该问题。
1495

被折叠的 条评论
为什么被折叠?



