cn.hutool.core.util.ZipUtil.addFile()方法的使用及代码示例

x33g5p2x  于2022-02-05 转载在 其他  
字(5.8k)|赞(0)|评价(0)|浏览(675)

本文整理了Java中cn.hutool.core.util.ZipUtil.addFile()方法的一些代码示例,展示了ZipUtil.addFile()的具体用法。这些代码示例主要来源于Github/Stackoverflow/Maven等平台,是从一些精选项目中提取出来的代码,具有较强的参考意义,能在一定程度帮忙到你。ZipUtil.addFile()方法的具体详情如下:
包路径:cn.hutool.core.util.ZipUtil
类名称:ZipUtil
方法名:addFile

ZipUtil.addFile介绍

[英]添加文件到压缩包
[中]添加文件到压缩包

代码示例

代码示例来源:origin: looly/hutool

/**
 * 添加文件到压缩包
 * 
 * @param file 需要压缩的文件
 * @param path 在压缩文件中的路径
 * @param out 压缩文件存储对象
 * @throws UtilException IO异常
 * @since 4.0.5
 */
private static void addFile(File file, String path, ZipOutputStream out) throws UtilException {
  BufferedInputStream in = null;
  try {
    in = FileUtil.getInputStream(file);
    addFile(in, path, out);
  } finally {
    IoUtil.close(in);
  }
}

代码示例来源:origin: looly/hutool

/**
 * 添加文件到压缩包
 * 
 * @param file 需要压缩的文件
 * @param path 在压缩文件中的路径
 * @param out 压缩文件存储对象
 * @throws UtilException IO异常
 * @since 4.0.5
 */
private static void addFile(File file, String path, ZipOutputStream out) throws UtilException {
  BufferedInputStream in = null;
  try {
    in = FileUtil.getInputStream(file);
    addFile(in, path, out);
  } finally {
    IoUtil.close(in);
  }
}

代码示例来源:origin: looly/hutool

/**
 * 对流中的数据加入到压缩文件<br>
 * 路径列表和流列表长度必须一致
 * 
 * @param zipFile 生成的Zip文件,包括文件名。注意:zipPath不能是srcPath路径下的子文件夹
 * @param paths 流数据在压缩文件中的路径或文件名
 * @param ins 要压缩的源
 * @param charset 编码
 * @return 压缩文件
 * @throws UtilException IO异常
 * @since 3.0.9
 */
public static File zip(File zipFile, String[] paths, InputStream[] ins, Charset charset) throws UtilException {
  if (ArrayUtil.isEmpty(paths) || ArrayUtil.isEmpty(ins)) {
    throw new IllegalArgumentException("Paths or ins is empty !");
  }
  if (paths.length != ins.length) {
    throw new IllegalArgumentException("Paths length is not equals to ins length !");
  }
  ZipOutputStream out = null;
  try {
    out = getZipOutputStream(zipFile, charset);
    for (int i = 0; i < paths.length; i++) {
      addFile(ins[i], paths[i], out);
    }
  } finally {
    IoUtil.close(out);
  }
  return zipFile;
}

代码示例来源:origin: looly/hutool

/**
 * 对流中的数据加入到压缩文件<br>
 * 路径列表和流列表长度必须一致
 * 
 * @param zipFile 生成的Zip文件,包括文件名。注意:zipPath不能是srcPath路径下的子文件夹
 * @param paths 流数据在压缩文件中的路径或文件名
 * @param ins 要压缩的源
 * @param charset 编码
 * @return 压缩文件
 * @throws UtilException IO异常
 * @since 3.0.9
 */
public static File zip(File zipFile, String[] paths, InputStream[] ins, Charset charset) throws UtilException {
  if (ArrayUtil.isEmpty(paths) || ArrayUtil.isEmpty(ins)) {
    throw new IllegalArgumentException("Paths or ins is empty !");
  }
  if (paths.length != ins.length) {
    throw new IllegalArgumentException("Paths length is not equals to ins length !");
  }
  ZipOutputStream out = null;
  try {
    out = getZipOutputStream(zipFile, charset);
    for (int i = 0; i < paths.length; i++) {
      addFile(ins[i], paths[i], out);
    }
  } finally {
    IoUtil.close(out);
  }
  return zipFile;
}

代码示例来源:origin: looly/hutool

/**
 * 递归压缩文件夹<br>
 * srcRootDir决定了路径截取的位置,例如:<br>
 * file的路径为d:/a/b/c/d.txt,srcRootDir为d:/a/b,则压缩后的文件与目录为结构为c/d.txt
 * 
 * @param out 压缩文件存储对象
 * @param srcRootDir 被压缩的文件夹根目录
 * @param file 当前递归压缩的文件或目录对象
 * @throws UtilException IO异常
 */
private static void zip(File file, String srcRootDir, ZipOutputStream out) throws UtilException {
  if (file == null) {
    return;
  }
  final String subPath = FileUtil.subPath(srcRootDir, file); // 获取文件相对于压缩文件夹根目录的子路径
  if (file.isDirectory()) {// 如果是目录,则压缩压缩目录中的文件或子目录
    final File[] files = file.listFiles();
    if (ArrayUtil.isEmpty(files) && StrUtil.isNotEmpty(subPath)) {
      // 加入目录,只有空目录时才加入目录,非空时会在创建文件时自动添加父级目录
      addDir(subPath, out);
    }
    // 压缩目录下的子文件或目录
    for (File childFile : files) {
      zip(childFile, srcRootDir, out);
    }
  } else {// 如果是文件或其它符号,则直接压缩该文件
    addFile(file, subPath, out);
  }
}

代码示例来源:origin: looly/hutool

/**
 * 递归压缩文件夹<br>
 * srcRootDir决定了路径截取的位置,例如:<br>
 * file的路径为d:/a/b/c/d.txt,srcRootDir为d:/a/b,则压缩后的文件与目录为结构为c/d.txt
 * 
 * @param out 压缩文件存储对象
 * @param srcRootDir 被压缩的文件夹根目录
 * @param file 当前递归压缩的文件或目录对象
 * @throws UtilException IO异常
 */
private static void zip(File file, String srcRootDir, ZipOutputStream out) throws UtilException {
  if (file == null) {
    return;
  }
  final String subPath = FileUtil.subPath(srcRootDir, file); // 获取文件相对于压缩文件夹根目录的子路径
  if (file.isDirectory()) {// 如果是目录,则压缩压缩目录中的文件或子目录
    final File[] files = file.listFiles();
    if (ArrayUtil.isEmpty(files) && StrUtil.isNotEmpty(subPath)) {
      // 加入目录,只有空目录时才加入目录,非空时会在创建文件时自动添加父级目录
      addDir(subPath, out);
    }
    // 压缩目录下的子文件或目录
    for (File childFile : files) {
      zip(childFile, srcRootDir, out);
    }
  } else {// 如果是文件或其它符号,则直接压缩该文件
    addFile(file, subPath, out);
  }
}

代码示例来源:origin: cn.hutool/hutool-all

/**
 * 添加文件到压缩包
 * 
 * @param file 需要压缩的文件
 * @param path 在压缩文件中的路径
 * @param out 压缩文件存储对象
 * @throws UtilException IO异常
 * @since 4.0.5
 */
private static void addFile(File file, String path, ZipOutputStream out) throws UtilException {
  BufferedInputStream in = null;
  try {
    in = FileUtil.getInputStream(file);
    addFile(in, path, out);
  } finally {
    IoUtil.close(in);
  }
}

代码示例来源:origin: cn.hutool/hutool-all

/**
 * 对流中的数据加入到压缩文件<br>
 * 路径列表和流列表长度必须一致
 * 
 * @param zipFile 生成的Zip文件,包括文件名。注意:zipPath不能是srcPath路径下的子文件夹
 * @param paths 流数据在压缩文件中的路径或文件名
 * @param ins 要压缩的源
 * @param charset 编码
 * @return 压缩文件
 * @throws UtilException IO异常
 * @since 3.0.9
 */
public static File zip(File zipFile, String[] paths, InputStream[] ins, Charset charset) throws UtilException {
  if (ArrayUtil.isEmpty(paths) || ArrayUtil.isEmpty(ins)) {
    throw new IllegalArgumentException("Paths or ins is empty !");
  }
  if (paths.length != ins.length) {
    throw new IllegalArgumentException("Paths length is not equals to ins length !");
  }
  ZipOutputStream out = null;
  try {
    out = getZipOutputStream(zipFile, charset);
    for (int i = 0; i < paths.length; i++) {
      addFile(ins[i], paths[i], out);
    }
  } finally {
    IoUtil.close(out);
  }
  return zipFile;
}

代码示例来源:origin: cn.hutool/hutool-all

/**
 * 递归压缩文件夹<br>
 * srcRootDir决定了路径截取的位置,例如:<br>
 * file的路径为d:/a/b/c/d.txt,srcRootDir为d:/a/b,则压缩后的文件与目录为结构为c/d.txt
 * 
 * @param out 压缩文件存储对象
 * @param srcRootDir 被压缩的文件夹根目录
 * @param file 当前递归压缩的文件或目录对象
 * @throws UtilException IO异常
 */
private static void zip(File file, String srcRootDir, ZipOutputStream out) throws UtilException {
  if (file == null) {
    return;
  }
  final String subPath = FileUtil.subPath(srcRootDir, file); // 获取文件相对于压缩文件夹根目录的子路径
  if (file.isDirectory()) {// 如果是目录,则压缩压缩目录中的文件或子目录
    final File[] files = file.listFiles();
    if (ArrayUtil.isEmpty(files) && StrUtil.isNotEmpty(subPath)) {
      // 加入目录,只有空目录时才加入目录,非空时会在创建文件时自动添加父级目录
      addDir(subPath, out);
    }
    // 压缩目录下的子文件或目录
    for (File childFile : files) {
      zip(childFile, srcRootDir, out);
    }
  } else {// 如果是文件或其它符号,则直接压缩该文件
    addFile(file, subPath, out);
  }
}

相关文章