使用 zipoutputstream 压缩文件的关键步骤包括:1. 导入必要的类,如 java.io.*、java.util.zip.zipentry 和 zipoutputstream;2. 创建 fileinputstream 读取文件,创建 zipoutputstream 指定输出路径;3. 创建 zipentry 并写入文件内容;4. 使用递归方法压缩整个文件夹,处理子文件和目录;5. 注意编码设置、资源关闭、压缩效率及避免重复条目。整个过程通过 try-with-resources 确保资源自动关闭,适合基础压缩需求。

Java 要压缩文件,用 ZipOutputStream 是一个比较基础但实用的方法。它属于 Java 标准库中的 java.util.zip 包,适合处理 ZIP 格式的压缩需求。如果你需要在程序中实现文件夹打包压缩功能,这个类很适合入门。

下面介绍几个关键点,帮助你快速理解怎么用 ZipOutputStream 来压缩文件。
1. 准备工作:导入必要的类
在开始之前,确保你导入了以下类:
立即学习“Java免费学习笔记(深入)”;

import java.io.*; import java.util.zip.ZipEntry; import java.util.zip.ZipOutputStream;
这些类是处理文件读写和 ZIP 压缩的基础。ZipOutputStream 是压缩的核心类,ZipEntry 表示压缩包中的一个条目(也就是一个文件或目录)。
2. 压缩单个文件的基本流程
压缩一个文件的逻辑比较简单,大致流程如下:

- 创建一个
FileInputStream读取原始文件内容; - 创建
ZipOutputStream,传入一个FileOutputStream,指定压缩文件的输出路径; - 创建
ZipEntry,设置文件名; - 把文件内容写入到 ZIP 输出流中;
- 关闭资源。
示例代码如下:
try (FileInputStream fis = new FileInputStream("test.txt");
ZipOutputStream zos = new ZipOutputStream(new FileOutputStream("test.zip"))) {
ZipEntry entry = new ZipEntry("test.txt");
zos.putNextEntry(entry);
byte[] buffer = new byte[1024];
int len;
while ((len = fis.read(buffer)) > 0) {
zos.write(buffer, 0, len);
}
zos.closeEntry();
} catch (IOException e) {
e.printStackTrace();
}这个例子压缩了一个叫 test.txt 的文件,输出为 test.zip。
3. 压缩整个文件夹:递归处理子文件
压缩整个文件夹稍微复杂一点,需要递归遍历目录下的所有子文件和子目录。关键点是:
- 如果是目录,也要创建一个对应的
ZipEntry(路径以/结尾); - 遇到文件就按上面的方法处理;
- 使用递归函数遍历所有文件。
下面是实现压缩文件夹的简化版本:
public static void zipDirectory(File dir, String parentPath, ZipOutputStream zos) throws IOException {
for (File file : dir.listFiles()) {
if (file.isDirectory()) {
zipDirectory(file, parentPath + dir.getName() + "/", zos);
} else {
try (FileInputStream fis = new FileInputStream(file)) {
String entryName = parentPath + file.getName();
zos.putNextEntry(new ZipEntry(entryName));
byte[] buffer = new byte[1024];
int len;
while ((len = fis.read(buffer)) > 0) {
zos.write(buffer, 0, len);
}
zos.closeEntry();
}
}
}
}调用时传入根目录和初始路径即可。
4. 注意事项和常见问题
使用 ZipOutputStream 时,有些细节容易被忽略:
-
编码问题:ZIP 文件默认使用本地编码,可能导致中文乱码。可以通过设置
ZipOutputStream的编码方式(比如使用setEncoding("UTF-8"))来避免; -
关闭资源:务必在
try-with-resources中使用流对象,或者手动关闭,否则可能造成资源泄漏; - 压缩效率:如果压缩的文件很多,可以考虑使用缓冲区大小优化,或者使用多线程压缩(但标准库不支持,需借助第三方库);
-
文件重复:不要重复添加相同路径的
ZipEntry,否则会抛异常。
基本上就这些。用 ZipOutputStream 实现压缩虽然不是最高效的方案,但足够简单,适用于大多数基础需求。如果你需要更多功能(比如分卷压缩、加密),可能要考虑使用 Apache Commons Compress 或者其他第三方库。










