一次性导出多个文件到zip包中,代码量很少就可解决

根据路径将其文件打包压缩成zip包,并导出到浏览器上。支持多个文件打包。

import javax.servlet.http.HttpServletResponse;
import org.springframework.http.MediaType;
import org.springframework.http.HttpHeaders;

import java.io.*;
import java.util.zip.ZipEntry;
import java.util.zip.ZipOutputStream;

public void downloadZip(HttpServletResponse response) {
   	try {
       	response.setContentType(MediaType.APPLICATION_OCTET_STREAM_VALUE);
       	response.setHeader(HttpHeaders.CONTENT_DISPOSITION, "attachment; filename=\"files.zip\"");
       	ZipOutputStream zipOut = new ZipOutputStream(response.getOutputStream());
		
		//如果导出的文件数量不确定,可自己加入for循环调用下面的addToZip()
       	addToZip("/home/files/template/111.pdf", zipOut);
       	addToZip("/home/files/template/222.pdf", zipOut);
       	
       	zipOut.close();
	} catch (Exception e) {
       e.printStackTrace();
   	}
}
/**
 * 处理zip文件下载
 * @param filePath 待打包的文件路径信息
 * @return
 */
private void addToZip(String filePath, ZipOutputStream zipOut) throws IOException {
	File file = new File(filePath);
    FileInputStream fis = new FileInputStream(file);
    ZipEntry zipEntry = new ZipEntry(file.getName());
    zipOut.putNextEntry(zipEntry);

    byte[] bytes = new byte[1024];
    int length;
    while ((length = fis.read(bytes)) >= 0) {
        zipOut.write(bytes, 0, length);
    }
    fis.close();
    zipOut.closeEntry();
}

至此为止,一次性导出多个文件到zip包中已完成。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个修改后的示例代码,可以一次请求导出多个Excel文件到浏览器: ```java import java.io.*; import javax.servlet.*; import javax.servlet.http.*; import org.apache.poi.hssf.usermodel.*; import org.apache.poi.ss.usermodel.*; public class ExcelExportServlet extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // 设置响应头,告诉浏览器返回的是Zip压缩文件 response.setContentType("application/zip"); response.setHeader("Content-Disposition", "attachment;filename=examples.zip"); // 创建Zip输出流 ZipOutputStream zipOut = new ZipOutputStream(response.getOutputStream()); // 循环导出多个Excel文件 for (int i = 1; i <= 3; i++) { // 创建Excel文件 HSSFWorkbook workbook = new HSSFWorkbook(); HSSFSheet sheet = workbook.createSheet("Sheet1"); // 添加数据到Excel文件 HSSFRow row = sheet.createRow(0); HSSFCell cell = row.createCell(0); cell.setCellValue("Hello, World! " + i); // 将Excel文件写入Zip输出流 ByteArrayOutputStream out = new ByteArrayOutputStream(); workbook.write(out); ZipEntry entry = new ZipEntry("example" + i + ".xls"); zipOut.putNextEntry(entry); zipOut.write(out.toByteArray()); zipOut.closeEntry(); out.close(); } // 关闭Zip输出流 zipOut.finish(); zipOut.close(); } } ``` 在上述代码,我们将响应头的内容类型设置为“application/zip”,表示返回的是一个Zip压缩文件。同时,我们创建了一个ZipOutputStream对象,表示输出的是一个Zip文件。然后,我们循环导出多个Excel文件,每个Excel文件的写入方式与之前的示例代码相同,但这次我们将写入的Excel文件先写入到一个ByteArrayOutputStream对象,然后再将其写入到Zip输出流。最后,我们关闭Zip输出流,这样浏览器就可以将其下载。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值