Java中如何读取和写入zip文件

在我们日常使用中,zip压缩文件是非常常用的,市面上也有许多压缩软件,那么我们为什么要用java去操作zip,使用压缩软件不香吗?其实试想有这样一个需求,在这个项目中,有上传功能,如果要上传多个文件,这样频繁的操作远远不如上传一个压缩包方便,上传后如果要操作这些压缩包里的文件,用IO流不就方便多了。因此就得先了解ZipInputStream类和ZipOutputStream类。

ZipInputStream:继承自FilterInputStream类,采用了装饰器模式,可以直接读取zip包中的内容, 内部封装有ZipEntry类型的属性,在读取zip文件内部子文件时,调用getNextEntry()方法时,每个ZipEntry对象就是每个子文件。

ZipOutputStream:继承自FilterOutputStream类,采用了装饰器模式,可以直接写入内容到zip包中, 内部同样封装有ZipEntry类型的属性,但是在写入Zip压缩文件时,调用putNextEntry()方法,需要把每个子文件作为ZipEntry对象传入。

读取Zip包(解压缩)

首先要创建解压缩目录targetDir,通常是与zip文件在同一个目录下,通过用zip文件的父目录与zip文件的文件名作为数据源,并调用mkdir()方法创建目录。

第二步就是解析并读取zip压缩文件,创建一个ZipInputStream,传入一个FileInputStream作为数据源,然后循环调用getNextEntry(),遍历zip文件每个子文件,每次循环获取子文件的文件名并创建该文件的输出流,调用write()方法,读取文件内容并写入输出流。代码如下:

import java.io.BufferedOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.nio.charset.Charset;
import java.util.zip.ZipEntry;
import java.util.zip.ZipInputStream;


public class Demo01 {
	public static void main(String[] args) {
		// 要进行解压缩的zip文件
		File zipFile = new File("D:\\test\\1-201023201325.zip");

		// 1.创建解压缩目录
		// 获取zip文件的名称
		String zipFileName = zipFile.getName();

		// 根据zip文件名称,提取压缩文件目录
		String targetDirName = zipFileName.substring(0, zipFileName.indexOf("."));

		// 创建解压缩目录
		File targetDir = new File(zipFile.getParent() + "\\" + targetDirName);

		if (!targetDir.exists()) {
			targetDir.mkdir(); // 创建目录
		}

		// 2.解析读取zip文件
		try (ZipInputStream in = new ZipInputStream(new FileInputStream(zipFile), Charset.forName("gbk"))) {
			// 遍历zip文件中的每个子文件
			ZipEntry zipEntry = null;
			while ((zipEntry = in.getNextEntry()) != null) {
				// 获取zip压缩包中的子文件名称
				String zipEntryFileName = zipEntry.getName();

				// 创建该文件的输出流
				String zipFilePath = targetDir.getPath() + "\\" + zipEntryFileName;
				
				// 输出流定义在try()块,结束自动清空缓冲区并关闭
				try (BufferedOutputStream bos = new BufferedOutputStream(new FileOutputStream(zipFilePath))) {

					// 读取该子文件的字节内容
					byte[] buff = new byte[1024];
					int len = -1;
					while ((len = in.read(buff)) != -1) {
						bos.write(buff, 0, len);
					}
				}
			}
		} catch (IOException e) {
			e.printStackTrace();
		}
	}
}

写入zip包(压缩)

首先创建File对象rootDir引用原始目录,然后创建一个ZipOutputStream,传入一FileOutputStream作为数据源,调用listFiles()方法,获取并遍历原始目录下的子文件列表,每次循环创建一个ZipEntry,每写入一个文件前,调用putNextEntry()方法,然后将原文件的字节内容,写入zip压缩包,需要注意,每次写完文件,必须调用closeEntry()结束当前ZipEntry。代码如下:

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.nio.file.Files;
import java.util.zip.ZipEntry;
import java.util.zip.ZipOutputStream;

public class Demo02 {
	public static void main(String[] args) {
		// 原始目录
		File rootDir = new File("D:\\test\\20220529");
		System.out.println(rootDir.getAbsolutePath());
		// 将原始目录中的文件,“写入”zip压缩文件
		try (ZipOutputStream out = new ZipOutputStream(
				new FileOutputStream(rootDir.getParent() + "\\" + rootDir.getName() + ".zip"))) {
			// 获取并遍历原始目录下的子文件列表
			File[] files = rootDir.listFiles();
			for (File f : files) {
				// 创建一个ZipEntry
				out.putNextEntry(new ZipEntry(f.getName()));

				// 将原文件的字节内容,写入zip压缩包
				out.write(Files.readAllBytes(f.toPath()));

				// 结束当前ZipEntry
				out.closeEntry();
			}
		} catch (IOException e) {
			e.printStackTrace();
		}
	}

}

  • 9
    点赞
  • 38
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 8
    评论
您可以使用JavaZipInputStream类来读取zip压缩文件,然后将数据写入数据库。以下是一个简单的示例代码: ```java import java.io.FileInputStream; import java.io.IOException; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.SQLException; import java.util.zip.ZipEntry; import java.util.zip.ZipInputStream; public class ZipFileReader { public static void main(String[] args) { String zipFilePath = "path/to/your/zip/file.zip"; String dbUrl = "jdbc:mysql://localhost:3306/mydatabase"; String dbUsername = "your-username"; String dbPassword = "your-password"; try { // 打开数据库连接 Connection conn = DriverManager.getConnection(dbUrl, dbUsername, dbPassword); // 创建插入数据的SQL语句 String insertQuery = "INSERT INTO your_table_name (file_name, file_data) VALUES (?, ?)"; // 创建PreparedStatement对象 PreparedStatement pstmt = conn.prepareStatement(insertQuery); // 创建ZipInputStream对象 ZipInputStream zipInput = new ZipInputStream(new FileInputStream(zipFilePath)); // 读取zip文件的每个条目 ZipEntry entry = zipInput.getNextEntry(); while (entry != null) { // 读取条目的文件名和数据 String fileName = entry.getName(); byte[] fileData = new byte[(int) entry.getSize()]; zipInput.read(fileData); // 设置参数并执行插入语句 pstmt.setString(1, fileName); pstmt.setBytes(2, fileData); pstmt.executeUpdate(); // 关闭当前条目,准备读取下一个条目 zipInput.closeEntry(); entry = zipInput.getNextEntry(); } // 关闭ZipInputStream、PreparedStatement和数据库连接 zipInput.close(); pstmt.close(); conn.close(); System.out.println("数据成功写入数据库!"); } catch (IOException | SQLException e) { e.printStackTrace(); } } } ``` 请将代码的以下内容替换为您自己的信息: - `zipFilePath`:您的zip文件的路径。 - `dbUrl`:您的数据库URL。 - `dbUsername`:您的数据库用户名。 - `dbPassword`:您的数据库密码。 - `your_table_name`:您要插入数据的表名。 这段代码将逐个读取zip文件的条目,并将每个条目的文件名和数据插入到数据库。您需要根据自己的需求修改代码以适应您的数据库结构和数据处理逻辑。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

仙草不加料

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值