解压时如何解压不产生子目录?

问题描述 投票:0回答:1

这就是 UnzipUtility 用于解压压缩文件的类,我面临的问题是,当我解压压缩文件时,我仍然有解压后的文件夹和它的内容,我需要跳过这一层进行解压,并直接拥有它的内容。

public class UnzipUtility {
/**
 * Size of the buffer to read/write data
 */
private static final int BUFFER_SIZE = 4096;
/**
 * Extracts a zip file specified by the zipFilePath to a directory specified by
 * destDirectory (will be created if does not exists)
 * @param zipFilePath
 * @param destDirectory
 * @throws IOException
 */
public void unzip(String zipFilePath, String destDirectory) throws IOException {
    File destDir = new File(destDirectory);
    if (!destDir.exists()) {
        destDir.mkdir();
    }
    ZipInputStream zipIn = new ZipInputStream(new FileInputStream(zipFilePath));
    ZipEntry entry = zipIn.getNextEntry();
    // iterates over entries in the zip file
    while (entry != null) {
        String filePath = destDirectory + File.separator + entry.getName();
        if (!entry.isDirectory()) {
            // if the entry is a file, extracts it
            extractFile(zipIn, filePath);
        } else {
            // if the entry is a directory, make the directory
            File dir = new File(filePath);
            dir.mkdir();
        }
        zipIn.closeEntry();
        entry = zipIn.getNextEntry();
    }
    zipIn.close();
}

/**
 * Extracts a zip entry (file entry)
 * @param zipIn
 * @param filePath
 * @throws IOException
 */
private void extractFile(ZipInputStream zipIn, String filePath) throws IOException {
    if(Files.notExists(new File(filePath).getParentFile().toPath())) {
        new File(filePath).getParentFile().mkdir();
    }
    BufferedOutputStream bos = new BufferedOutputStream(new FileOutputStream(filePath));
    byte[] bytesIn = new byte[BUFFER_SIZE];
    int read = 0;
    while ((read = zipIn.read(bytesIn)) != -1) {
        bos.write(bytesIn, 0, read);
    }
    bos.close();
}

}

java unzip
1个回答
0
投票

我实现了这个问题的解决方案,只需添加第三个参数,指定提取的根目录在zip中,这样我们提取zip文件的内容时就没有它的父文件夹了。

public class UnzipUtility {
/**
 * Size of the buffer to read/write data
 */
private static final int BUFFER_SIZE = 4096;

/**
 * Extracts a zip file specified by the zipFilePath to a directory specified by
 * destDirectory (will be created if does not exists)
 */
public void unzip(String zipFilePath, String destDirectory, String rootLevelDir) throws IOException {

    if(rootLevelDir == null || rootLevelDir.isEmpty()){
        rootLevelDir="/";
    }
    File destDir = new File(destDirectory);
    if (!destDir.exists()) {
        destDir.mkdirs();
    }
    try(ZipInputStream zipIn = new ZipInputStream(new FileInputStream(zipFilePath))) {
        ZipEntry entry = zipIn.getNextEntry();
        // iterates over entries in the zip file
        while (entry != null) {
            String filePath = destDirectory + File.separator + entry.getName();
            if ( rootLevelDir.equals("/") || entry.getName().startsWith(rootLevelDir)) {

                if (!rootLevelDir.equals("/")) {
                    filePath = filePath.replaceFirst(rootLevelDir, "");
                }
                if (!entry.isDirectory()) {
                    // if the entry is a file, extracts it
                    extractFile(zipIn, filePath);
                } else {
                    // if the entry is a directory, make the directory
                    File dir = new File(filePath);
                    dir.mkdirs();
                }
            }
            zipIn.closeEntry();
            entry = zipIn.getNextEntry();
        }
    }
}

/**
 * Extracts a zip entry (file entry)
 */
private void extractFile(ZipInputStream zipIn, String filePath) throws IOException {
    if (Files.notExists(new File(filePath).getParentFile().toPath())) {
        new File(filePath).getParentFile().mkdirs();
    }
    try(BufferedOutputStream bos = new BufferedOutputStream(new FileOutputStream(filePath))) {
        byte[] bytesIn = new byte[BUFFER_SIZE];
        int read;
        while ((read = zipIn.read(bytesIn)) != -1) {
            bos.write(bytesIn, 0, read);
        }
    }
}

}

© www.soinside.com 2019 - 2024. All rights reserved.