你是一个资深java工程师,请使用ServletOutputStream 和BufferedInputStream下载多个excel 文件
时间: 2023-10-25 17:22:26 浏览: 134
好的,可以使用以下代码实现:
```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());
byte[] buffer = new byte[1024];
// 待下载的文件列表
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);
// 创建一个新的压缩项
zos.putNextEntry(new ZipEntry(fileName));
// 创建一个缓冲输入流
BufferedInputStream bis = new BufferedInputStream(fis);
// 写入压缩数据
int len;
while ((len = bis.read(buffer)) > 0) {
zos.write(buffer, 0, len);
}
// 关闭输入流和压缩项
bis.close();
zos.closeEntry();
}
// 关闭压缩流
zos.close();
}
```
该代码会将多个excel文件压缩成一个zip文件,并通过ServletOutputStream将zip文件发送到客户端进行下载。其中,使用了BufferedInputStream来提高读取文件的效率,同时也使用了缓冲区来减少网络传输次数。