zip压缩文件的读取和写入


前言

在Java中,zip压缩文件是怎样读取和写入的?这里我们需要引入ZipInputStream 和 ZipOutputStream。

一、ZipInputStream

ZipInputStream是一种读取zip压缩文件的输入流,它的基本用法:创建一个ZipInputStream对象,因为它继承自FiterInputStream,因此它创建对象必须传入一个输入流(例如:FileInputStream)作为数据源,然后调用getNextEntry()方法,直到返回null,表示zip流结束。
一个ZipEntry对象可能表示一个压缩文件或目录,如果是压缩文件,调用read()方法不断读取,直到返回-1;
代码示例如下:

public static void main(String[] args) {
		// 要进行解压的zip文件
		File zipFile = new File("D:\\Desktop.zip");

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

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

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

		while (!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 out = new BufferedOutputStream(new FileOutputStream(zipFilePath));) {
					// 读取该子文件的字节内容
					byte[] buff = new byte[1024];
					int len = -1;
					while ((len = in.read(buff)) != -1) {
						out.write(buff, 0, len);
					}
				}
			}
		} catch (IOException e) {
			e.printStackTrace();
		}

	}

二、ZipOutputStream

ZipOutputStream是一种将内容写入zip压缩文件的输出流,它继承自FiterOutputStream,它的基本用法:创建一个ZipOutputStream对象,它创建对象必须传入一个输出流(例如:FileOutputStream),每写入一个文件前,先调用putNextEntry(),然后调用write()方法写入byte[ ]数据,最后调用closeEntry()结束文件的打包。
代码示例如下:

public static void main(String[] args) {
		//原始目录
		File rootDir = new File("D:\\Desktop");
		//将原始目录中的文件,“写入”zip压缩文件
		try (ZipOutputStream out = new ZipOutputStream(
				 new FileOutputStream(rootDir.getParent()+"//"+rootDir.getName()+"1.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();
		}
	}
  • 7
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您可以使用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文件中的条目,并将每个条目的文件名和数据插入到数据库中。您需要根据自己的需求修改代码以适应您的数据库结构和数据处理逻辑。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值