Java把文件压缩成.zip压缩包和解压.zip压缩包

简介: Java把文件压缩成.zip压缩包和解压.zip压缩包

压缩成.zip

代码如下:

/**
     * 压缩成ZIP
     *
     * @param srcDir           压缩文件夹路径
     * @param out              压缩文件输出流
     * @throws RuntimeException 压缩失败会抛出运行时异常
     */

public static void toZip(String srcDir, OutputStream out) throws RuntimeException {

    long start = System.currentTimeMillis();

    ZipOutputStream zos = null;

    try {

        zos = new ZipOutputStream(out);

        File sourceFile = new File(srcDir);

        compress(sourceFile, zos, sourceFile.getName(), false);

        long end = System.currentTimeMillis();

        System.out.println("压缩完成,耗时:" + (end - start) + " ms");

    } catch (Exception e) {

        throw new RuntimeException("zip error from ZipUtils", e);

    } finally {

        if (zos != null) {

            try {

                zos.close();

            } catch (IOException e) {

                e.printStackTrace();

            }

        }

    }
}

/**
     * 递归压缩方法
     *
     * @param sourceFile       源文件
     * @param zos              zip输出流
     * @param name             压缩后的名称
     * @param KeepDirStructure 是否保留原来的目录结构,true:保留目录结构;
     *                         <p>
     *                         false:所有文件跑到压缩包根目录下(注意:不保留目录结构可能会出现同名文件,会压缩失败)
     * @throws Exception
     */
private static void compress(File sourceFile, ZipOutputStream zos, String name,
                             boolean KeepDirStructure) throws Exception {
    byte[] buf = new byte[BUFFER_SIZE];

    if (sourceFile.isFile()) {

        // 向zip输出流中添加一个zip实体,构造器中name为zip实体的文件的名字

        zos.putNextEntry(new ZipEntry(name));

        // copy文件到zip输出流中

        int len;

        FileInputStream in = new FileInputStream(sourceFile);

        while ((len = in.read(buf)) != -1) {

            zos.write(buf, 0, len);

        }

        // Complete the entry

        zos.closeEntry();

        in.close();

    } else {

        File[] listFiles = sourceFile.listFiles();

        if (listFiles == null || listFiles.length == 0) {

            // 需要保留原来的文件结构时,需要对空文件夹进行处理

            if (KeepDirStructure) {

                // 空文件夹的处理

                zos.putNextEntry(new ZipEntry(name + "/"));

                // 没有文件,不需要文件的copy

                zos.closeEntry();
            }

        } else {

            for (File file : listFiles) {

                // 判断是否需要保留原来的文件结构

                if (KeepDirStructure) {

                    // 注意:file.getName()前面需要带上父文件夹的名字加一斜杠,

                    // 不然最后压缩包中就不能保留原来的文件结构,即:所有文件都跑到压缩包根目录下了

                    compress(file, zos, name + "/" + file.getName(), KeepDirStructure);

                } else {

                    compress(file, zos, file.getName(), KeepDirStructure);

                }


            }

        }

    }

}

测试验证代码:

/**
     * 测试打包本地的Navicat,输出为zip文件
     * @throws Exception
     */
@Test
public void test() throws Exception {
    //Navicat路径
    String inDir = "E:\\developer\\Navicat";
    //打包后输出路径
    String outDir = "E:\\developer\\NavicatZip\\Navicat.zip";
    OutputStream fileOutputStream = new FileOutputStream(new File(outDir));
    ZipUtils.toZip(inDir, fileOutputStream);
}

打包前后的文件如下:
image.pngimage.png

解压.zip

代码如下:

/**
     * 解压zip文件到指定目录
     * @param fileZip
     * @param path_to_dest
     * @throws IOException
     */
public static void readZip(String fileZip,String path_to_dest) throws IOException {

    try (FileInputStream fis = new FileInputStream(fileZip);
         ZipInputStream zis =
         new ZipInputStream(new BufferedInputStream(fis))) {

        ZipEntry entry;

        // 从ZipInputStream读取每个条目,直到没有
        // 发现更多条目,返回值为空
        // getNextEntry()方法。
        while ((entry = zis.getNextEntry()) != null) {
            System.out.println("Unzipping: " + entry.getName());

            int size;
            byte[] buffer = new byte[2048];
            File fileOut = new File(path_to_dest+"\\"+entry.getName());
            try (FileOutputStream fos =
                 new FileOutputStream(fileOut);
                 BufferedOutputStream bos =
                 new BufferedOutputStream(fos, buffer.length)) {

                while ((size = zis.read(buffer, 0, buffer.length)) != -1) {
                    bos.write(buffer, 0, size);
                }
                bos.flush();
            }
        }
    } catch (IOException e) {
        e.printStackTrace();
    }
}

测试验证代码:

/**
     * 测试解压本地zip文件
     * @throws Exception
     */
@Test
public void readZip() throws Exception {
    //解压后路径
    String path_to_dest = "E:\\developer\\NavicatUnzip";
    //zip文件路径
    String fileZip = "E:\\developer\\NavicatZip\\Navicat.zip";
    ZipUtils.readZip(fileZip, path_to_dest);
}

解压前后的文件如下:

image.png

相关文章
|
1月前
|
Java
java小工具util系列5:java文件相关操作工具,包括读取服务器路径下文件,删除文件及子文件,删除文件夹等方法
java小工具util系列5:java文件相关操作工具,包括读取服务器路径下文件,删除文件及子文件,删除文件夹等方法
74 9
|
1月前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
76 2
|
17天前
|
Java
java实现从HDFS上下载文件及文件夹的功能,以流形式输出,便于用户自定义保存任何路径下
java实现从HDFS上下载文件及文件夹的功能,以流形式输出,便于用户自定义保存任何路径下
80 34
|
1月前
|
消息中间件 存储 Java
RocketMQ文件刷盘机制深度解析与Java模拟实现
【11月更文挑战第22天】在现代分布式系统中,消息队列(Message Queue, MQ)作为一种重要的中间件,扮演着连接不同服务、实现异步通信和消息解耦的关键角色。Apache RocketMQ作为一款高性能的分布式消息中间件,广泛应用于实时数据流处理、日志流处理等场景。为了保证消息的可靠性,RocketMQ引入了一种称为“刷盘”的机制,将消息从内存写入到磁盘中,确保消息持久化。本文将从底层原理、业务场景、概念、功能点等方面深入解析RocketMQ的文件刷盘机制,并使用Java模拟实现类似的功能。
42 3
|
1月前
|
Java 测试技术 Maven
Maven clean 提示文件 java.io.IOException
在使用Maven进行项目打包时,遇到了`Failed to delete`错误,尝试手动删除目标文件也失败,提示`java.io.IOException`。经过分析,发现问题是由于`sys-info.log`文件被其他进程占用。解决方法是关闭IDEA和相关Java进程,清理隐藏的Java进程后重新尝试Maven clean操作。最终问题得以解决。总结:遇到此类问题时,可以通过任务管理器清理相关进程或重启电脑来解决。
|
1月前
|
Java Android开发
Eclipse 创建 Java 包
Eclipse 创建 Java 包
33 1
|
1月前
|
存储 缓存 安全
在 Java 编程中,创建临时文件用于存储临时数据或进行临时操作非常常见
在 Java 编程中,创建临时文件用于存储临时数据或进行临时操作非常常见。本文介绍了使用 `File.createTempFile` 方法和自定义创建临时文件的两种方式,详细探讨了它们的使用场景和注意事项,包括数据缓存、文件上传下载和日志记录等。强调了清理临时文件、确保文件名唯一性和合理设置文件权限的重要性。
96 2
|
1月前
|
存储 安全 Java
如何保证 Java 类文件的安全性?
Java类文件的安全性可以通过多种方式保障,如使用数字签名验证类文件的完整性和来源,利用安全管理器和安全策略限制类文件的权限,以及通过加密技术保护类文件在传输过程中的安全。
58 4
|
Java 大数据 Apache