当前位置: 首页 > 文档资料 > PclZip 中文文档 >

可选参数

优质
小牛编辑
132浏览
2023-12-01

英文原文:http://www.phpconcept.net/pclzip/user-guide/5

可选参数(普通参数)

  • PCLZIP_OPT_PATH
  • PCLZIP_OPT_ADD_PATH
  • PCLZIP_OPT_REMOVE_PATH
  • PCLZIP_OPT_REMOVE_ALL_PATH
  • PCLZIP_OPT_SET_CHMOD
  • PCLZIP_OPT_BY_NAME
  • PCLZIP_OPT_BY_EREG
  • PCLZIP_OPT_BY_PREG
  • PCLZIP_OPT_BY_INDEX
  • PCLZIP_OPT_EXTRACT_AS_STRING
  • PCLZIP_OPT_EXTRACT_IN_OUTPUT
  • PCLZIP_OPT_NO_COMPRESSION
  • PCLZIP_OPT_COMMENT
  • PCLZIP_OPT_ADD_COMMENT
  • PCLZIP_OPT_PREPEND_COMMENT
  • PCLZIP_OPT_REPLACE_NEWER
  • PCLZIP_OPT_EXTRACT_DIR_RESTRICTION
  • PCLZIP_OPT_STOP_ON_ERROR
  • PCLZIP_OPT_TEMP_FILE_ON
  • PCLZIP_OPT_TEMP_FILE_THRESHOLD
  • PCLZIP_OPT_TEMP_FILE_OFF

参数有 2 大类:

  • 普通变量:传递操作信息到方法
  • 回调函数:供用户在 PclZip 处理过程中进行一些操作

回调函数可能有些难理解,不过可提供对压缩包更好的操作方式。

这些可选参数是一些常量,实质是一些静态整数。 参数对应的参数值,可以是单个值,也可以是一个列表。 有时某些参数无需设置值,因为参数名本身已包含了必须信息。

下面将列举所有的可选参数:

PCLZIP_OPT_PATH

此参数指明压缩包的内容将被解压到的目录。

参数值:一个字符串。

$list = $archive->extract(PCLZIP_OPT_PATH, "extract/folder/");

此参数可用于以下方法:

  • extract()
  • extractByIndex()

PCLZIP_OPT_ADD_PATH

此参数用于在解压或压缩时为文件添加路径。如,压缩时可将file.txt文件以backup/file.txt路径 放到压缩包中;解压时可将data/file.txt解压到folder/data/file.txt (译注:folder没有出现在下面例子中)。

$list = $archive->create(
    "file.txt,image.gif",
    PCLZIP_OPT_ADD_PATH, "backup"
);

此参数可用于以下方法:

  • create()
  • add()
  • extract()

PCLZIP_OPT_REMOVE_PATH

此参数用于在解压或压缩时去掉一些前缀路径。 如,压缩时可将/usr/local/user/test/file.txt压缩为test/file.txt; 解压时将压缩包内的folder/data/file.txt解压为data/file.txt

参数值:一个字符串。

$list = $archive->add(
    "/usr/local/user/test/file.txt",
    PCLZIP_OPT_REMOVE_PATH, "/usr/local/user"
);

此参数可用于以下方法:

  • create()
  • add()
  • extract()
  • extractByIndex()

注意:在同一方法调用中,若已指定PCLZIP_OPT_REMOVE_ALL_PATH参数,则本参数将自动被忽略。

PCLZIP_OPT_REMOVE_ALL_PATH

此参数用于在解压或压缩时,去掉文件的所有路径(译注:即所有文件都放在根目录下,没有任何子目录)。

使用此参数时无需指定任何路径,有时简单理解为PCLZIP_OPT_REMOVE_PATH参数的批量操作。 但此参数使用时需注意,应保证不同子目录中不存在同名的文件。

本参数没有参数值。

$list = $archive->create(
    "data/file.txt images/image.gif",
    PCLZIP_OPT_REMOVE_ALL_PATH
);
// 上面会从 'data/file.txt' 中去掉 'data/'
// 并从 'images/image.gif' 中去掉 'images/'

此参数可用于以下方法:

  • create()
  • add()
  • extract()
  • extractByIndex()

PCLZIP_OPT_SET_CHMOD

此参数用于在解压后对文件的权限进行修改。

在类 *NIIX 系统中,文件管理系统和文件拥有者一般不允许对系统的所有文件进行访问。 特别的,启动 PHP 进程的用户会对解压出来的文件进行保护,一般不允许其他用户对 其进行访问。

本参数会尝试对解压出来的文件的权限进行修改,如允许写访问,但不修改文件的拥有者。

参数值:一个八进制值(如 0777)

$list = $archive->extract(PCLZIP_OPT_SET_CHMOD, 0777);

此参数可用于以下方法:

  • extract()
  • extractByIndex()

PCLZIP_OPT_BY_NAME

此参数用于只解压出某些文件/目录。

(译注:下面例子假设test.zip压缩包中至少有这两个文件)

$archive = new PclZip('test.zip');
$rule_list[0] = 'data/file1.txt';
$rule_list[1] = 'data/file2.txt';
$list = $archive->extract(PCLZIP_OPT_BY_NAME, $rule_list);
if ($list == 0) {
    echo "ERROR : " . $archive->errorInfo(true);
}

参数值,允许两种情况:

  • 一个数组
  • 一个字符串,字符串内文件列表用英文逗号隔开
$archive = new PclZip('test.zip');
$list = $archive->extract(PCLZIP_OPT_BY_NAME, "data/file1.txt,data/file2.txt");
if ($list == 0) {
    echo "ERROR : " . $archive->errorInfo(true);
}

PCLZIP_OPT_BY_EREG

此参数用于以正则表达式的方式过滤将被解压的文件/目录。

此参数基于 PHP 自带的 ereg() 函数。 (译注:ereg 在 PHP7 中将不能用)

$archive = new PclZip('test.zip');
$list = $archive->extract(PCLZIP_OPT_BY_EREG, "txt$");
if ($list == 0) {
  echo "ERROR : " . $archive->errorInfo(true);
}

PCLZIP_OPT_BY_PREG

此参数用于以正则表达式的方式过滤将被解压的文件/目录。

此参数基于 PHP 自带的 preg_match() 函数。 (译注:建议使用本参数,而非PCLZIP_OPT_BY_EREG

$archive = new PclZip('test.zip');
$list = $archive->extract(PCLZIP_OPT_BY_PREG, "txt$");
if ($list == 0) {
  echo "ERROR : " . $archive->errorInfo(true);
}

PCLZIP_OPT_BY_INDEX

此参数允许以指定压缩包内的文件索引方式来解压文件/目录。

$archive = new PclZip('test.zip');
$list = $archive->extract(PCLZIP_OPT_BY_INDEX, ['0-4', '2-7', '10-33']);
if ($list == 0) {
  echo "ERROR : " . $archive->errorInfo(true);
}

PCLZIP_OPT_EXTRACT_AS_STRING

此参数用于将压缩包内的文件内容直接解压到 PHP 字符串中,而非文件中,不依赖文件系统。

此参数的用途,如:

  • 显示一个 readme 文件
  • 直接将压缩包内文件的内容直接显示在标准输出中(见参数PCLZIP_OPT_EXTRACT_IN_OUTPUT

若想将压缩包内的所有文件都解压到 PHP 字符串中,将消耗较大的内存,请防止内存使用超过 PHP 配置的限制。

$archive = new PclZip('test.zip');
$list = $archive->extract(
    PCLZIP_OPT_BY_NAME, "data/readme.txt",
    PCLZIP_OPT_EXTRACT_AS_STRING
);
if ($list == 0) {
  echo "ERROR : " . $archive->errorInfo(true);
  exit;
}
echo $list[0]['content'];

PCLZIP_OPT_EXTRACT_IN_OUTPUT

此参数用于直接将压缩包内文件的内容直接显示在标准输出中(类似echo的功能)。

$archive = new PclZip('test.zip');
$list = $archive->extract(
    PCLZIP_OPT_BY_NAME, "data/readme.txt",
    PCLZIP_OPT_EXTRACT_IN_OUTPUT
);
if ($list == 0) {
  echo "ERROR : " . $archive->errorInfo(true);
}

PCLZIP_OPT_NO_COMPRESSION

此参数用于添加不压缩的文件到压缩包。

$archive = new PclZip('test.zip');
$list = $archive->add("data/file.txt", PCLZIP_OPT_NO_COMPRESSION);
if ($list == 0) {
  echo "ERROR : " . $archive->errorInfo(true);
}

PCLZIP_OPT_COMMENT

此参数用于为压缩包内的文件设置一个注释字符串,若已有注释,将替换原有注释。

$archive = new PclZip('test.zip');
$list = $archive->create(
    "data", 
    PCLZIP_OPT_COMMENT, "Add a comment"
);
if ($list == 0) {
  echo "ERROR : " . $archive->errorInfo(true);
}

PCLZIP_OPT_ADD_COMMENT

此参数用于为压缩包内的文件添加注释字符串,若已有注释,则追加到已有注释后面。

$archive = new PclZip('test.zip');
$list = $archive->add(
    "data", 
    PCLZIP_OPT_ADD_COMMENT, "Add a comment after the existing one"
);
if ($list == 0) {
  echo "ERROR : " . $archive->errorInfo(true);
}

PCLZIP_OPT_PREPEND_COMMENT

此参数用于为压缩包内的文件添加注释字符串,若已有注释,则添加到已有注释之前。

$archive = new PclZip('test.zip');
$list = $archive->add(
    "data", 
    PCLZIP_OPT_PREPEND_COMMENT, "Add a comment before the existing one"
);
if ($list == 0) {
  echo "ERROR : " . $archive->errorInfo(true);
}

PCLZIP_OPT_REPLACE_NEWER

默认情况下,PclZip 解压文件时,若文件系统中已存在文件,有两种情况:

  • 文件系统中的文件时间比压缩包内的文件时间旧,则解压时替换已有文件
  • 文件系统中的文件时间比压缩包内的文件时间新,则解压时不替换已有文件

本参数用于替换所有已有文件,不管时间新旧。

这对于还原一个备份时比较有用。

$archive = new PclZip('test.zip');
$list = $archive->extract(
    PCLZIP_OPT_BY_NAME, "data/readme.txt",
    PCLZIP_OPT_REPLACE_NEWER
);
if ($list == 0) {
    echo "ERROR : " . $archive->errorInfo(true);
}

PCLZIP_OPT_EXTRACT_DIR_RESTRICTION

PclZip 允许解压文件到系统的任意位置,但有人想通过解压到某些位置来覆盖系统文件(如密码文件)或其他文件, 这不安全。

此参数可用于只允许解压到指定目录,而不能解压到其他目录。

此参数可方便的以少量代码减少一些简单的错误。

注意:若要更安全的目录限制,请使用 PHP 的配置选项。

下面例子将不允许任何解压到非/var/www/data目录中。

$archive = new PclZip('test.zip');
$list = $archive->extract(PCLZIP_OPT_EXTRACT_DIR_RESTRICTION, "/var/www/data");
if ($list == 0) {
    echo "ERROR : " . $archive->errorInfo(true);
}

PCLZIP_OPT_STOP_ON_ERROR

默认情况下,解压时,若遇到某些文件不能成功解压,PclZip 并不会自动停止后面文件的解压。 全部解压完毕后,将返回一个解压后的文件列表状态结果(可见于extract()页面)。 列表中的每个值都包含每个文件/目录的解压状态。

本参数用于在解压遇到 1 个文件解压失败时就立即停止后续文件的解压。 这可方便你在解压刚出错后进行一些已解压文件的清理或其他操作。

$archive = new PclZip('test.zip');
$list = $archive->extract(
    PCLZIP_OPT_ADD_PATH, "extract_folder/",
    PCLZIP_OPT_STOP_ON_ERROR
);
if ($list == 0) {
  if ($archive->errorCode() == PCLZIP_ERR_ALREADY_A_DIRECTORY) {
    echo "ERROR : File tries to replace a folder !";
  }
}

PCLZIP_OPT_TEMP_FILE_ON

PCLZIP_OPT_TEMP_FILE_OFF

PCLZIP_OPT_TEMP_FILE_THRESHOLD

PclZip 从 v2.7 开始支持压缩或解压时使用临时文件,以更好支持大文件。

大部分情况下,PclZip 都在内存中进行操作,如读取所有文件、压缩文件、写文件到压缩包中。 使用临时文件时,PclZip 在压缩文件时将每次只读取大文件的其中一小块(2048 字节), 并直接将已压缩的小块先写入到临时文件中。当临时文件已写入到压缩包中,则删除该临时文件。

在 v2.8 中,解压时也支持类似的临时文件机制。

当压缩或解压大文件时,PclZip 很快会超过 PHP 配置中设置的内存限制(php.ini文件中的memory_limit选项) 而导致操作失败。通过使用临时文件,对大文件操作时将提高操作成功率。 但是,相对于在内存中操作,使用临时文件会降低性能。

从 v2.7 开始,PclZip 能自动检测文件的大小,并根据memory_limit的选择值,判断是否该采用临时文件方案。 有下面几个参数可配置:

  • PCLZIP_OPT_ADD_TEMP_FILE_ON

    全部使用临时文件

  • PCLZIP_OPT_ADD_TEMP_FILE_THRESHOLD

    超出本参数阈值大小的文件将使用临时文件,否则使用内存

  • PCLZIP_OPT_ADD_TEMP_FILE_OFF

    全部使用内存,全部不使用临时文件

PCLZIP_OPT_TEMP_FILE_ON的示例:

include_once('pclzip.lib.php');

$archive = new PclZip('archive.zip');
$v_list = $archive->create(
    'data/image-1.jpg,data/image-2.jpg',
    PCLZIP_OPT_REMOVE_PATH, 'data',
    PCLZIP_OPT_ADD_TEMP_FILE_ON
);
if ($v_list == 0) {
    die("Error : " . $archive->errorInfo(true));
}

PCLZIP_OPT_TEMP_FILE_THRESHOLD的示例:

include_once('pclzip.lib.php');

$archive = new PclZip('archive.zip');
$v_list = $archive->create(
    'data/image-1.jpg,data/image-2.jpg',
    PCLZIP_OPT_REMOVE_PATH, 'data',
    PCLZIP_OPT_TEMP_FILE_THRESHOLD, 10
);
if ($v_list == 0) {
    die("Error : " . $archive->errorInfo(true));
}

PCLZIP_OPT_TEMP_FILE_OFF的示例:

include_once('pclzip.lib.php');
ini_set('memory_limit', '180M');
$archive = new PclZip('archive.zip');
$v_list = $archive->create(
    'data/image-1.jpg,data/image-2.jpg',
    PCLZIP_OPT_REMOVE_PATH, 'data',
    PCLZIP_OPT_TEMP_FILE_OFF
);
if ($v_list == 0) {
    die("Error : " . $archive->errorInfo(true));
}

此参数可用于以下方法:

  • create()
  • add()
  • extract()
  • extractByIndex()

注意:本参数将取代下面这些参数(若存在)

  • PCLZIP_OPT_ADD_TEMP_FILE_ON
  • PCLZIP_OPT_ADD_TEMP_FILE_THRESHOLD
  • PCLZIP_OPT_ADD_TEMP_FILE_OFF

可选参数(回调函数)

回调函数(Call-back)可作为一种特殊参数,因为其中是一个函数名。 回调函数应严格遵守一些约定,并有不同的分类。 回调函数中可以做任何事,但都应接收约定的参数,并返回约定的值。 回调函数中不应进行一些特殊的操作,如在处理过程中把压缩包删除了,这是不合理的。

PCLZIP_CB_PRE_EXTRACT(解压前的回调)

本参数用于在解压压缩包内的每个文件前执行一些操作,包括:

  • 修改解压后的文件路径或文件名
  • 跳过某些文件(即不解压压缩包内某些文件)

此回调函数是在以下参数发生作用后执行的:

  • PCLZIP_OPT_PATH
  • PCLZIP_OPT_ADD_PATH
  • PCLZIP_OPT_REMOVE_PATH
  • PCLZIP_OPT_REMOVE_ALL_PATH

但会在相关检查之前执行(如文件不存在、目录不存在)。

本回调函数作为一个参数值放到 PclZip 的方法中,并应遵循下面约定:

function myCallBack($p_event, &$p_header)
{
    // ... 你的逻辑代码 ...
    return $result;
}

当 PclZip 方法调起回调函数时,会给回调函数传入两个变量:

  • $p_event:回调参数的标识符(在这里就是PCLZIP_CB_PRE_EXTRACT),多个回调函数使用同一个函数时会比较有用。
  • $p_header:将被解压的文件的信息,是一个数组,里面包含几个信息字段。其中常用的是:
    • 压缩包内的文件名
    • 想解压到的文件位置

更详细的$p_header结构见返回值页面。

本回调函数中$p_header中可以被修改的字段:

  • filename字段,即想解压到的文件位置。
  • 其他字段,均只读,不能修改

本回调函数的返回值应是以下值之一:

  • 0:表示跳过,不解压当前文件
  • 1:表示解压将继续,只是可能会按照本回调函数中修改的文件名进行解压
  • 2:表示跳过,不解压当前文件,也不再解压后续的文件
  • 其他值:为未来备用(译注:n 年过去了貌似这个未来还没到)
function myPreExtractCallBack($p_event, &$p_header)
{
    $info = pathinfo($p_header['filename']);
    // ----- 跳过 gif 格式文件
    if ($info['extension'] == 'gif') {
      return 0;
    }
    // ----- 所有 jpg 文件都解压到 images 目录
    else if ($info['extension'] == 'jpg') {
      $p_header['filename'] = 'images/' . $info['basename'];
      return 1;
    }
    // ----- 其他所有文件都直接正常解压
    else {
      return 1;
    }
}

$list = $archive->extract(
    PCLZIP_OPT_PATH, 'folder',
    PCLZIP_CB_PRE_EXTRACT, 'myPreExtractCallBack'
);

上述例子中,实现了以下功能:

  • 跳过 gif 格式文件
  • 所有 jpg 文件都解压到 images 目录
  • 其他所有文件都直接正常解压

PCLZIP_CB_POST_EXTRACT(解压后的回调)

本参数用于在解压压缩包内的每个文件后执行一些操作, 本参数不会对解压过程本身进行修改,但作用包括:

  • 重命名已解压的文件/目录
  • 删除已解压的文件/目录

本回调函数作为一个参数值放到 PclZip 的方法中,并应遵循下面约定:

function myCallBack($p_event, &$p_header)
{
    // ... 你的逻辑代码 ...
    return $result;
}

当 PclZip 方法调起回调函数时,会给回调函数传入两个变量:

  • $p_event:回调参数的标识符(在这里就是PCLZIP_CB_POST_EXTRACT),多个回调函数使用同一个函数时会比较有用。
  • $p_header:将被解压的文件的信息,是一个数组,里面包含几个信息字段。其中常用的是:
    • 解压后的文件名
    • 解压操作的执行状态

更详细的$p_header结构见返回值页面。

本回调函数中$p_header中的字段都不应被修改,因为所有字段都已包含了足够的信息。

本回调函数的返回值应是以下值之一:

  • 1:表示后续文件的解压将继续
  • 2:表示不再解压后续的文件
  • 其他值:为未来备用
function myPreExtractCallBack($p_event, &$p_header) { ... }

function myPostExtractCallBack($p_event, &$p_header)
{
    // ----- 判断是否已成功解压
    if ($p_header['status'] == 'ok') {
      // ----- 读取已解压文件内容到标准输入中
      readfile($p_header['filename']);
      // ----- 删除文件
      unlink($p_header['filename'])
    }
}

$list = $archive->extract(
    PCLZIP_OPT_PATH, 'temp',
    PCLZIP_CB_PRE_EXTRACT, 'myPreExtractCallBack',
    PCLZIP_CB_POST_EXTRACT, 'myPostExtractCallBack'
);

上述例子中,实现了以下功能:

  • 将所有解压成功的文件内容输出到标准输出中
  • 并在解压后删除已解压的文件

注意:从 v2.1 开始,若想实现上述例子的功能,建议使用PCLZIP_OPT_EXTRACT_IN_OUTPUT参数, 而非本回调函数,因为那样就不会在文件系统中产生临时文件。

PCLZIP_CB_PRE_ADD(添加到压缩包前的回调)

本参数用于在添加文件到压缩包前执行一些操作,包括:

  • 修改被压缩文件在压缩包中的文件名或路径
  • 跳过,不添加某些文件到压缩包

此回调函数是在以下参数发生作用后执行的:

  • PCLZIP_OPT_PATH
  • PCLZIP_OPT_ADD_PATH
  • PCLZIP_OPT_REMOVE_PATH
  • PCLZIP_OPT_REMOVE_ALL_PATH

但会在检查文件名长度之前执行。

本回调函数作为一个参数值放到 PclZip 的方法中,并应遵循下面约定:

function myCallBack($p_event, &$p_header)
{
    // ... 你的逻辑代码 ...
    return $result;
}

当 PclZip 方法调起回调函数时,会给回调函数传入两个变量:

  • $p_event:回调参数的标识符(在这里就是PCLZIP_CB_PRE_ADD),多个回调函数使用同一个函数时会比较有用。
  • $p_header:将被添加到压缩包的文件信息,是一个数组,里面包含几个信息字段。其中常用的是:
    • 文件压缩前的名字和路径
    • 文件在压缩包中的名字和路径

更详细的$p_header结构见返回值页面。

本回调函数中$p_header中可以被修改的字段:

  • filename字段,即文件在压缩包中的文件位置。
  • 其他字段,均只读,不能修改

本回调函数的返回值应是以下值之一:

  • 0:表示跳过,不添加当前文件当压缩包中,但会继续后续其他文件的添加
  • 1:表示压缩将继续,只是可能会按照本回调函数中修改的文件名进行压缩
  • 其他值:为未来备用
function myPreAddCallBack($p_event, &$p_header)
{
    $info = pathinfo($p_header['stored_filename']);
    // ----- bak 格式的文件跳过,不添加到压缩包
    if ($info['extension'] == 'bak') {
      return 0;
    }
    // ----- jpg 文件添加到压缩包时,放在压缩包内的 images 目录中
    else if ($info['extension'] == 'jpg') {
      $p_header['stored_filename'] = 'images/'.$info['basename'];
      return 1;
    }
    // ----- 其他所有文件都按正常方式添加到压缩包中
    else {
      return 1;
    }
}

$list = $archive->add(PCLZIP_CB_PRE_ADD, 'myPreAddCallBack');

上述例子中,实现了以下功能:

  • bak 格式的文件跳过,不添加到压缩包
  • jpg 文件添加到压缩包时,放在压缩包内的 images 目录中
  • 其他所有文件都按正常方式添加到压缩包中

PCLZIP_CB_POST_ADD(添加到压缩包后的回调)

本参数用于在添加文件到压缩包后执行一些操作,虽然不可修改已添加到压缩包内的文件,但可以:

  • 删除或修改文件系统中已添加到压缩包中的文件

本回调函数作为一个参数值放到 PclZip 的方法中,并应遵循下面约定:

function myCallBack($p_event, &$p_header)
{
    // ... 你的逻辑代码 ...
    return $result;
}

当 PclZip 方法调起回调函数时,会给回调函数传入两个变量:

  • $p_event:回调参数的标识符(在这里就是PCLZIP_CB_POST_ADD),多个回调函数使用同一个函数时会比较有用。
  • $p_header:将已添加到压缩包的文件信息,是一个数组,里面包含几个信息字段。其中常用的是:
    • 文件在压缩包中的名字和路径

更详细的$p_header结构见返回值页面。

本回调函数中$p_header中的字段都不应被修改,因为所有字段都已包含了足够的信息。

本回调函数的返回值应是以下值之一:

  • 1:必须返回 1(译注:暂无解释)
  • 其他值:为未来备用
function myPostAddCallBack($p_event, &$p_header)
{
    // ----- 判断添加到压缩包是否成功
    if ($p_header['status'] == 'ok') {
      // ----- 将文件系统中的文件移动到文件系统的 trash 目录
      rename($p_header['filename'], 'trash/'.$p_header['filename'])
    }
}

$list = $archive->extract(PCLZIP_CB_POST_ADD, 'myPostAddCallBack');

上述例子中,实现了以下功能:

  • 在添加到压缩包成功后,将文件系统中的文件移动到文件系统的 trash 目录