你是一个资深java工程师,请使用ServletOutputStream 下载多个excel 文件
时间: 2024-02-27 07:56:32 浏览: 158
好的,可以使用以下代码实现:
```java
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
response.setContentType("application/octet-stream");// 设置文件类型
response.setHeader("Content-Disposition", "attachment;filename=download.zip");// 设置文件名
//创建一个压缩流
ZipOutputStream zos = new ZipOutputStream(response.getOutputStream());
// 待下载的文件列表
List<String> fileList = new ArrayList<>();
fileList.add("file1.xlsx");
fileList.add("file2.xlsx");
fileList.add("file3.xlsx");
for (String fileName : fileList) {
// 读取excel文件内容
FileInputStream fis = new FileInputStream(fileName);
byte[] buffer = new byte[fis.available()];
fis.read(buffer);
fis.close();
// 创建一个新的压缩项
zos.putNextEntry(new ZipEntry(fileName));
// 写入压缩数据
zos.write(buffer);
// 关闭压缩项
zos.closeEntry();
}
// 关闭压缩流
zos.close();
}
```
该代码会将多个excel文件压缩成一个zip文件,并通过ServletOutputStream将zip文件发送到客户端进行下载。