- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在尝试创建一个备份类,其主要目标是自定义类调用,以便根据用户选择仅针对特定扩展名、特定文件大小或主目录中的特定目录过滤最终备份.
目前,该类(class)缺少压缩算法,因为我一直在寻找有关 .zip 压缩的解决方案。
这是一个文件和文件夹结构的例子,该类将使用它来创建压缩存档(zip、rar、gz 等):
Array
(
[0] => pclzip.lib.php
[1] => index.php
[style] => Array
(
[js] => Array
(
[0] => jNice.js
[1] => jquery.js
)
[img] => Array
(
[0] => input-shaddow-hover.gif
[1] => btn_right.gif
[2] => top-menu-bg.gif
[3] => top-menu-item-bg.gif
[4] => left-menu-bg.gif
[5] => button-submit.gif
[6] => btn_left.gif
[7] => select_right.gif
[8] => select_left.gif
[9] => transdmin-light.png
[10] => content.gif
[11] => input-shaddow.gif
)
[css] => Array
(
[0] => transdmin.css
[1] => layout.css
[2] => ie7.css
[3] => hack.css
[4] => jNice.css
[5] => ie6.css
[6] => reset.css
)
)
[2] => config.php
[3] => delete.php
[4] => restore.php
[5] => cron.php
[6] => manage.php
)
如您所见,备份文件中需要维护文件和文件夹结构,因此要备份的文件和文件夹列表已经结构化,如果数组叶子包含子数组,则叶子是一个 DIRECTORY,如果叶子不包含子数组,则该叶子是一个 FILE。
这是我创建递归压缩文件和文件夹的过程的目的,这些文件和文件夹(应该)适用于我之前介绍的结构化数组:
private function zipFileAndFolderStructureArray ( $backupContentsArray, $zipDestination, $backupRootDirectory ) {
if ( $this -> zipObject == null ) {
if ( extension_loaded ( 'zip' ) === true ) {
$this -> zipObject = new ZipArchive();
if ( ( $zipErrorCode = $this -> zipObject -> open ( $zipDestination, ZipArchive::CREATE ) ) !== true ) $this -> zipObject = null;
else $this -> zipFileAndFolderStructureArray ( $backupContentsArray, $zipDestination, $backupRootDirectory );
}
}
else if ( $this -> zipObject != null ) {
foreach ( $backupContentsArray as $folder => $file_or_folder_list ) {
$cwd = rtrim ( $backupRootDirectory, '/' ) . '/' . $folder . '/';
if ( is_array ( $file_or_folder_list ) && is_dir ( $cwd . $folder ) ) {
echo 'adding folder ' . $folder . ' in cwd ' . $cwd . '<br>';
$this -> zipObject -> addEmptyDir ( $folder );
$this -> zipFileAndFolderStructureArray ( $file_or_folder_list, $zipDestination, $cwd );
}
else if ( is_file ( $cwd . $file_or_folder_list ) ) {
echo 'adding file ' . $file_or_folder_list . '<br>';
$this -> zipObject -> addFromString ( $cwd . $file_or_folder_list );
}
}
$this -> zipObject -> close ();
return true;
}
}
问题是,我卡在了这一点上。此递归函数在输入第一个文件夹叶后存在,创建一个其中只有一个空文件夹的存档。
你能帮我找出问题所在吗?
关于我可以用来将压缩功能扩展到 RAR 和 GZ 的可能类的提示,尽可能多地重用用于 ZIP 的相同压缩算法?
提前致谢
P.S 添加了创建文件夹和目录结构的当前函数
public function directory_list ( $directory_base_path, $filter_dir = false, $filter_files = false, $exclude_empty_dirs = true, $include_extensions = null, $exclude_extensions = null, $exclude_files = null, $recursive = true ) {
$directory_base_path = rtrim ($directory_base_path, "/" ) . "/";
if ( ! is_dir ( $directory_base_path ) ) return false;
$result_list = array();
if ( ! is_array ( $exclude_files ) ) $exclude_array = Array ( '.', '..' );
else $exclude_array = array_merge ( Array ( '.', '..' ), $exclude_files );
if ( ! $folder_handle = opendir ( $directory_base_path ) ) return false;
else{
while ( false !== ( $filename = readdir ( $folder_handle ) ) ) {
if ( ! in_array ( $filename, $exclude_array ) ) {
if ( is_dir ( $directory_base_path . $filename . "/" ) ) {
if ( $recursive && strcmp ( $filename, "." ) != 0 && strcmp ( $filename, ".." ) != 0 ) { // prevent infinite recursion
$result = self::directory_list("$directory_base_path$filename/", $filter_dir, $filter_files, $exclude_empty_dirs, $include_extensions, $exclude_extensions, $exclude_files, $recursive);
if ( $exclude_empty_dirs ) {
if ( count ( array_keys ( $result ) ) > 0 ) $result_list[$filename] = $result;
}
else $result_list[$filename] = $result;
}
else if ( ! $filter_dir ) $result_list[] = $filename;
}
else if ( ! $filter_files ) {
$extension = end ( explode ( '.', $filename ) );
if ( ! is_array ( $include_extensions ) && count ( $include_extensions ) == 0 && ! is_array ( $exclude_extensions ) && count ( $exclude_extensions ) == 0 ) if ( $filename != '.' && $filename != '..' ) $result_list[] = $filename;
if ( is_array ( $exclude_extensions ) && count ( $exclude_extensions ) > 0 && ! in_array ( $extension, $exclude_extensions ) ) $result_list[] = $filename;
else if ( is_array ( $include_extensions ) && count ( $include_extensions ) > 0 && strlen ( $extension ) > 0 && in_array ( $extension, $include_extensions ) ) $result_list[] = $filename;
}
}
}
closedir($folder_handle);
return $result_list;
}
}
最佳答案
在调查并回应了递归 zip 算法中的几乎所有内容后,发现文件夹结构难以处理,需要大量修复路径中的斜杠。
这是同一个 zipFileAndFolderStructureArray 函数的固定版本
private function zipFileAndFolderStructureArray ( $backupContentsArray, $zipDestination, $backupRootDirectory, $currentWorkingDirectory = '' ) {
if ( $this -> zipObject == null ) {
if ( extension_loaded ( 'zip' ) === true ) {
$this -> zipObject = new ZipArchive();
if ( ( $zipErrorCode = $this -> zipObject -> open ( $zipDestination, ZipArchive::CREATE ) ) !== true ) $this -> zipObject = '#ERROR#';
else $this -> zipFileAndFolderStructureArray ( $backupContentsArray, $zipDestination, $backupRootDirectory );
}
}
else if ( $this -> zipObject == '#ERROR#' ) return false; // return false in case the zipArchive::open returned false on archive opening
else {
foreach ( $backupContentsArray as $folder => $file_or_folder_list ) {
if ( is_array ( $file_or_folder_list ) ) {
$current_working_folder = rtrim ( $currentWorkingDirectory, '/' ) . '/' . $folder . '/';
if ( is_dir ( $backupRootDirectory . $current_working_folder ) ) {
// not necessary to add an empty folder in this case: the addFile will take care of creating the folder structure in the zip file
$this -> zipFileAndFolderStructureArray ( $file_or_folder_list, $zipDestination, $backupRootDirectory, rtrim ( $current_working_folder, '/' ) );
}
}
else if ( is_file ( $backupRootDirectory . trim ( $currentWorkingDirectory, '/' ) . '/' . $file_or_folder_list ) ) {
$file_insertion = $backupRootDirectory . trim ( $currentWorkingDirectory, '/' ) . '/' . $file_or_folder_list;
$zip_filename = str_replace ( $backupRootDirectory, '', $file_insertion );
if ( substr_count ( $zip_filename, '/' ) == 1 ) $zip_filename = trim ( $zip_filename, '/' ); // file in backup root directory fix
$this -> zipObject -> addFile ( $file_insertion, $zip_filename );
}
}
return true;
}
}
关于php - 从文件和文件夹的结构化数组创建 ZIP/RAR/GZ 存档,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13956281/
我想将所有 .gz 文件解压缩到一个文件夹中,然后将它们合并到一个新文件中。我可以在不为每个 .gz 文件生成未压缩文件的情况下执行此操作吗? 非常感谢! 最佳答案 你可以这样做: zcat *.gz
我有以下问题:我正在编写一个函数来查找一堆 .gz 文件,解压缩它们,并将单独解压缩的文件存储在更大的 .tar.gz 中 存档。到目前为止,我设法用下面的代码实现它,但手动计算未压缩的文件大小并设置
有没有办法读取 tar 文件格式的文件时间戳,以便为解压文件设置相同的时间。 例如:Tar 文件中有多个文件,我想读取一个文件的最后修改时间戳。 请查找下面使用的代码。 我正在使用 apache co
我需要在目录中找到所有 .gz 文件但不是 .tar.gz 文件,然后发送所有 。 gz 文件到 some_other_command 进行处理。 到目前为止我可以做到: 找到 . -regextyp
我的逐行读取文件的脚本如下, file= "/c/User/XXX/Desktop/XYZ.log" while IFS= read -r line do if echo $line | gr
我有一个 db.tar.gz 文件(大约 500mb),我正在使用 vagrant (unix) 终端解压缩该文件。 使用以下instructions在这里,我使用gunzip尝试使用下面的命令解压缩
我有一堆 filename.bz2.gz 的文件,我想将其转换为 filename.gz。 有什么帮助吗? 谢谢 最佳答案 有了您的文件名*.bz2.gz,我假设该文件是使用以下压缩顺序创建的: ec
我在 Linux 上有一个 250GB 的 gzip 文件,我想将它分成 250 个 1GB 的文件并即时压缩生成的部分文件(一旦生成一个文件,它就应该被压缩)。我试过用这个 - zcat file.
我制作了我的文件夹的两个压缩副本,首先使用命令 tar czf dir.tar.gz dir这给了我一个大小为 ~16kb 的存档。然后我尝试了另一种方法,首先我将所有文件压缩到目录中,然后使用 gz
是否有一种简单明了的方法来递归解压 war/ear/pack.gz/tar.gz 类型的嵌套文件,从而创建一个目录树 - war 中的耳朵等也如此? 我不在乎它是在标准 shell 中还是在 java
我正在尝试获取一个正则表达式(在 bash 中)来识别仅具有以下扩展名的文件: tgz、tar.gz、TGZ 和 TAR.GZ。 我尝试了几个但无法让它工作。 我使用此正则表达式来仅选择具有这些扩展名
我正在开发一个有关 UNIX 联机帮助页的项目,我意识到其中一些联机帮助页以 .1.gz 的形式成对存在。和.1posix.gz . 为什么有两个关于同一个实用程序的联机帮助页(我主要对第 1 部分感
我压缩了一个文件夹并在压缩时将其拆分为 200mb 的 tar.gz 文件。我怎样才能解压缩它们?有没有一种方法可以在一个命令中执行此操作,还是我必须分别执行每个命令? 最佳答案 您甚至不能单独进行。
我已经使用手动 gzip 手动压缩了我的 CSS,并且我正在尝试包含来自外部源的 css.gz。 " type="text/css" media="screen" /> 当我使用 PHP 和 Apac
我有一个命令可以从现有文件创建一个新的 .tar.gz 文件, sudo tar -zcvf Existing.tar.gz New.tar.gz 此命令将从现有的 Existing.tar.gz
目前,我有以/path_to_file/file.txt.gz 结尾的文件。 我想拆分提取文件名(在 .txt.gz 之前)。 x = os.path.basename("/path_to_file/
仅从字符串 89dde7.rqsnhq34h.fmu8s1vn0i94hl.tgz.tar.gz 中删除 .tar.gz 部分,结果应为 89dde7.rqsnhq34h.fmu8s1vn0i94hl
前几天开始下载了 http://geolite.maxmind.com/download/geoip/database/GeoLiteCountry/GeoIP.dat.gz http://geoli
//, 这个问题有点模棱两可。 场景如下: 我有以下三个扩展名的日志,但我当前的规则仅适用于 *.log 文件: .1 .log .txt 另外,因为 Tomcat 正在轮换日志,所以我有以下内容:
详细说明, 我的 AWS S3 上有一个 tar.gz 文件,我们将其命名为 example.tar.gz。 所以,我想要做的是将 example.tar.gz 的提取内容下载到 /var/home/
我是一名优秀的程序员,十分优秀!