背景:

在Java中,可以使用java.util.zip包提供的类来进行文件的压缩和解压缩操作。主要涉及的类有ZipOutputStreamZipEntryZipInputStreamInflaterInputStream

压缩文件的步骤和原理:

  1. 创建一个FileOutputStream对象,用于将压缩后的数据写入到文件中。

  2. 创建一个BufferedOutputStream对象,将其包装在FileOutputStream中,以提高写入性能。

  3. 创建一个ZipOutputStream对象,将其包装在BufferedOutputStream中,用于将数据压缩为ZIP格式。

  4. 遍历要压缩的文件列表,对于每个文件执行以下操作:

    • 创建一个ZipEntry对象,表示要添加到ZIP文件中的文件或目录。
    • 使用ZipOutputStreamputNextEntry()方法将ZipEntry添加到ZIP输出流中。
    • 如果当前要添加的条目是目录,可以跳过文件内容的读取和写入步骤。
    • 如果当前要添加的条目是文件,可以执行以下操作:
      • 打开要添加的文件。
      • 创建一个缓冲区字节数组,用于读取文件内容。
      • 使用FileInputStream读取文件内容到缓冲区中。
      • 使用ZipOutputStreamwrite()方法将缓冲区中的数据写入ZIP输出流。
    • 使用ZipOutputStreamcloseEntry()方法关闭当前ZIP条目的写入。

5. 在完成所有文件的压缩后,关闭ZipOutputStream,以确保所有数据都被写入到ZIP文件中。

示例代码

import java.io.*;
import java.util.zip.*; public class FileCompressor {
public static void compressFile(String sourceFilePath, String zipFilePath) throws IOException {
// 创建源文件的File对象
File sourceFile = new File(sourceFilePath); // 创建用于写入压缩数据的输出流
try (
FileOutputStream fos = new FileOutputStream(zipFilePath); // 用于写入ZIP文件的FileOutputStream
BufferedOutputStream bos = new BufferedOutputStream(fos); // 用于提高写入效率的BufferedOutputStream
ZipOutputStream zos = new ZipOutputStream(bos) // 用于压缩数据的ZipOutputStream
) {
// 递归地压缩源文件
compressRecursive(sourceFile, sourceFile.getName(), zos);
}
} private static void compressRecursive(File file, String parentPath, ZipOutputStream zos) throws IOException {
if (file.isDirectory()) {
// 如果文件是目录,则创建相应的目录条目并关闭条目
String entryPath = parentPath + File.separator + file.getName();
ZipEntry entry = new ZipEntry(entryPath + File.separator);
zos.putNextEntry(entry);
zos.closeEntry(); // 获取目录中的子文件和子目录
File[] children = file.listFiles();
if (children != null) {
for (File child : children) {
// 递归地压缩子文件和子目录
compressRecursive(child, entryPath, zos);
}
}
} else {
// 如果文件是普通文件,则创建相应的文件条目并写入文件数据
try (
FileInputStream fis = new FileInputStream(file); // 用于读取文件数据的FileInputStream
BufferedInputStream bis = new BufferedInputStream(fis) // 用于提高读取效率的BufferedInputStream
) {
// 创建文件条目并将其加入到压缩流中
String entryPath = parentPath + File.separator + file.getName();
ZipEntry entry = new ZipEntry(entryPath);
zos.putNextEntry(entry); // 使用缓冲区读取文件数据并写入压缩流中
byte[] buffer = new byte[1024];
int bytesRead;
while ((bytesRead = bis.read(buffer)) != -1) {
zos.write(buffer, 0, bytesRead);
} // 关闭文件条目
zos.closeEntry();
}
}
}
} 

主要涉及类及其作用:

  1. ZipOutputStream:这个类是用于创建ZIP文件并将数据压缩为ZIP格式的主要类。它实现了OutputStream接口,可以向输出流写入ZIP格式的数据。

  2. ZipEntry:这个类表示ZIP文件中的一个条目,可以是文件或目录。它包含了条目的名称、大小、压缩比等信息,并可以作为一个完整的数据单元添加到ZipOutputStream中。

  3. ZipInputStream:这个类是用于从ZIP文件中读取数据并进行解压缩的主要类。它实现了InputStream接口,可以从输入流中读取ZIP格式的数据。

  4. InflaterInputStream:这个类是ZipInputStream的子类,用于解压缩被压缩的数据。它通过使用Inflater对象将压缩数据解压缩为原始数据。

  5. FileInputStream:这个类是用于从文件中读取数据的类。它实现了InputStream接口,可以从输入流中读取文件数据。

  6. FileOutputStream:这个类是用于将数据写入文件的类。它实现了OutputStream接口,可以将数据写入输出流中。

  7. BufferedInputStreamBufferedOutputStream:这两个类是用于提高输入输出性能的类。它们分别将一个输入流和输出流包装在内部,并提供了缓冲区,可以减少对底层流的直接读写操作,从而提高读写效率。

  8. File:这个类是用于表示文件或目录的类。它提供了方法来操作文件的属性、路径、名称等信息。

Java实现压缩文件浅谈的更多相关文章

  1. java的反射机制浅谈(转)

    原文链接:java的反射机制浅谈 一.java的反射机制浅谈 1.何谓反射机制 根据网文,java中的反射机制可以如此定义: JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性 ...

  2. java ZIP压缩文件

    问题描述:     使用java ZIP压缩文件和目录 问题解决:     (1)单个文件压缩 注:     以上是实现单个文件写入压缩包的代码,注意其中主要是在ZipOutStream流对象中创建Z ...

  3. java ZipOutputStream压缩文件,ZipInputStream解压缩

    java中实现zip的压缩与解压缩.java自带的 能实现的功能比较有限. 本程序功能:实现简单的压缩和解压缩,压缩文件夹下的所有文件(文件过滤的话需要对File进一步细节处理). 对中文的支持需要使 ...

  4. java生成压缩文件

    在工作过程中,需要将一个文件夹生成压缩文件,然后提供给用户下载.所以自己写了一个压缩文件的工具类.该工具类支持单个文件和文件夹压缩.放代码: import java.io.BufferedOutput ...

  5. java打包压缩文件

    package com.it.simple.util; import java.io.BufferedOutputStream;import java.io.ByteArrayOutputStream ...

  6. Java实现压缩文件与解压缩文件

    由于工作需要,需要将zip的压缩文件进行解压,经过调查发现,存在两个开源的工具包,一个是Apache的ant工具包,另一个就是Java api自带的工具包:但是Java自带的工具包存在问题:如果压缩或 ...

  7. java对压缩文件进行加密,winrar和好压 直接输入解密密码来使用

    <!-- https://mvnrepository.com/artifact/net.lingala.zip4j/zip4j --> <dependency> <gro ...

  8. Java生成压缩文件(zip、rar 格式)

    jar坐标: <dependency> <groupId>org.apache.ant</groupId> <artifactId>ant</ar ...

  9. Java读取压缩文件信息

    不解压压缩文件,获取其中包含的文件,通过文件名检查是否包含非法文件.(后续再根据文件头或内容吧) zip: import java.util.zip.ZipEntry;import java.util ...

  10. java zip 压缩文件

    zip压缩:ZipOutputStream.ZipFile.ZipInputStream 三个类的作用 一段 java  zip  压缩的代码: File dir = new File("C ...

随机推荐

  1. excel怎么固定前几行前几列不滚动?

    在Excel中,如果你想固定前几行或前几列不滚动,可以通过以下几种方法来实现.详细的介绍如下: **固定前几行不滚动:** 1. 选择需要固定的行数.例如,如果你想要固定前3行,应该选中第4行的单元格 ...

  2. 基于DotNetty实现自动发布 - 项目的配置与发现

    前言 上一篇,我们实现了基于 DotNetty 的通信基础模块的搭建,本篇,主要实现待发布 Web 项目的集成. 创建待发布项目 为了测试, 我创建了一个基于 .NET 4.8 的 Web 项目 Op ...

  3. [GDOIpj222B] 网页浏览

    第二题 网页浏览 提交文件: webpage.cpp 输入文件: webpage.in 输出文件: webpage.out 时间空间限制: 1 秒, 256 MB 我们在上网时,从一个网页上的链接打开 ...

  4. TypeError: 'module' object is not callable (pytorch在进行MNIST数据集预览时出现的错误)

    在使用pytorch在对MNIST数据集进行预览时,出现了TypeError: 'module' object is not callable的错误: 上报错信息图如下: 从图中可以看出,报错位置为第 ...

  5. 高斯朴素贝叶斯(Gaussian Naive Bayes)原理与实现——垃圾邮件识别实战

    朴素贝叶斯(Naive Bayes): 根据贝叶斯定理和朴素假设提出的朴素贝叶斯模型. 贝叶斯定理: 朴素假设(特征条件独立性假设): 代入可知朴素贝叶斯模型计算公式: 因为朴素贝叶斯是用来分类任务, ...

  6. 【笔记整理】[案例]爱词霸翻译post请求

    import json if __name__ == '__main__': import requests resp = requests.post( url="http://ifanyi ...

  7. ElasticSearch之Refresh API

    使用本方法,显式的执行refresh操作. 默认情况下,ElasticSearch启动后台任务,周期性执行refresh操作,周期使用参数index.refresh_interval控制. 本方法触发 ...

  8. Sliver 二开准备

    cs被杀麻了,最近打算看看一下sliver的源码进行一下二开,这篇是记录遇到的一些问题 编译sliver Windows下 官方说用MingW,但是我自己用他带的make不行, ​​ ‍ 下载make ...

  9. Supershell防溯源反制配置

    简介 项目地址:https://github.com/tdragon6/Supershell Supershell是一个集成了reverse_ssh服务的WEB管理平台,使用docker一键部署(快速 ...

  10. spring自定义session分布式session

    spring实现自定义session.springboot实现自定义session.自定义sessionid的key.value.实现分布式会话 一.原始方案 自定义生成sessionid的值 修改t ...