PHP zip解压缩类PclZip使用方法总结
PHP zip解压缩方法很多,除了php自带的解压缩扩展实现外,下面介绍一种功能强大PHP ZIP加压缩类。
PHP zip解压缩类PclZip介绍
PclZip library能够压缩与解压缩Zip格式的压缩档(WinZip、PKZIP);且能对此类类档案进行处理,包括产生压缩档、列出压缩档的内容以及解压缩档案等等。由于能够在伺服器端进行压缩与解压缩的动作,所以相当方便使用。
PclZip定义一个PclZip类别,其类别物件可视为一个ZIP档案,亦提供method来进行处理。
如何使用PHP zip解压缩类PclZip
1.基础
所有的功能都由pclzip.lib.php这个档案提供,PclZip library可于其首页(www.phpconcept.net/pclzip/index.en.php)下载。所有的PKZIP档案其实就是一个PclZip的类别物件。当产生一个PclZip档案(ie, PclZip类别物件),就会先产生一个压缩档,且档名已经指定,但此压缩档的内容尚未存在:
< ?PHP <br /> require_once('pclzip.lib.php'); <br /> $archive = new PclZip("archive.zip"); <br />?>
此物件提供了一些public method可用来处理此档案。
2.参数
每一个method有其各自可使用的参数,包括有必须与非必须的参数:< ?PHP <br /> require_once('pclzip.lib.php'); <br /> $archive = new PclZip('archive.zip'); <br /> <br /> $v_list = $archive->add('dev/file.txt', <br /> PCLZIP_OPT_REMOVE_PATH, 'dev'); <br />?>
上例中的'dev/file.txt'就是必须参数;'PCLZIP_OPT_REMOVE_PATH'则为非必须参数。当然有些method也可以只包含非必须的参数:
< ?PHP <br /> $list = $archive->extract(PCLZIP_OPT_PATH, "folder", <br /> PCLZIP_OPT_REMOVE_PATH, "data", <br /> PCLZIP_CB_PRE_EXTRACT, "callback_pre_extract",); <br />?>
上例中原本压缩档内档案存放的路径为/data,不过你可以指定解压缩至/folder中。此外,在解压缩之前,会呼叫callback function('callback_pre_extract()'),此function可让使用者在解压缩的过程中变更档案存放路径与档名,或是选择某些档案不解压缩。
3.回传值
每个method所回传的值可能会不同,将会在每个method中说明。不过大部分的method回传0、error或是阵列。
4.错误处理
从版本1.3之后,错误处理已经整合至PclZip类别中,当一个method回传错误码,可以得知一些额外的讯息以方便错误处理:* errorName():回传错误名称
* errorCode():回传错误码
* errorInfo():回传错误的描述接下来会举几个例子来说明如何使用PclZip。PclZip实例1、产生ZIP压缩档
PclZip($zipname):为PclZip constructor,$zipname为PKZIP压缩档的档名。
主要是产生一个PclZip物件,即一个PKZIP压缩档;但此时,只有压缩档产生出来,并做一些检查(例如是否有开启zlib extension...等),除此之外,并没有做其他动作。
create($filelist, [optional arguments list]):将参数$filelist指定的档案或目录(包含当中所有档案与子目录)加入上述所产生的压缩档中。
而非必要的参数则能够修改压缩档内的档案存放路径。
此method可用的参数可以参考网志(www.phpconcept.net/pclzip/man/en/index.php)。
下面的示例说明如何产生PKZIP压缩档(档名为archive.zip),并将file.txt、data/text.txt以及目录folder(包含当中的档案与子目录)加入刚刚产生的archive.zip中:
< ?PHP<br /> include_once('pclzip.lib.php');<br /> $archive = new PclZip('archive.zip');<br /> $v_list = $archive->create('file.txt,data/text.txt,folder');<br /> if ($v_list == 0) {<br /> die("Error : ".$archive->errorInfo(true));<br /> }<br />?>
下面的示例说明基本上与上例一样产生archive.zip,但在将file.txt与text.txt压缩于其中时,将路径由data/改为install/ ;因此,在archive.zip中这两个档案的路径会是install/file.txt与install/text.txt
< ?PHP<br /> include_once('pclzip.lib.php');<br /> $archive = new PclZip('archive.zip');<br /> $v_list = $archive->create('data/file.txt,data/text.txt',<br /> PCLZIP_OPT_REMOVE_PATH, 'data',<br /> PCLZIP_OPT_ADD_PATH, 'install');<br /> if ($v_list == 0) {<br /> die("Error : ".$archive->errorInfo(true));<br /> }<br /><p>?></p>
PHP zip解压缩类PclZip实例
1、列出压缩档内容
listContent( ) :列出压缩档中的内容,包括档案的属性与目录:
<span style="font-size: 14px;">< ?PHP</span><br /> include_once('pclzip.lib.php');<br /> $zip = new PclZip("test.zip");<br /> <br /> if (($list = $zip->listContent()) == 0) {<br /> die("Error : ".$zip->errorInfo(true));<br /> }<br /> <br /> for ($i=0; $i<sizeof ($list); $i++) {<br /> for(reset($list[$i]); $key = key($list[$i]); next($list[$i])) {<br /> echo "File $i / [$key] = ".$list[$i][$key]."<br />";<br /> }<br /> echo "<br />";<br /> }<br /><p>?><span style="font-size: 14px;">
File 0 / [filename] = data/file1.txt
File 0 / [stored_filename] = data/file1.txt
File 0 / [size] = 53
File 0 / [compressed_size] = 36
File 0 / [mtime] = 1010440428
File 0 / [comment] =
File 0 / [folder] = 0
File 0 / [index] = 0
File 0 / [status] = okFile 1 / [filename] = data/file2.txt
File 1 / [stored_filename] = data/file2.txt
File 1 / [size] = 54
File 1 / [compressed_size] = 53
File 1 / [mtime] = 1011197724
File 1 / [comment] =
File 1 / [folder] = 0
File 1 / [index] = 1
File 1 / [status] = ok
2、解压缩档案
extract([options list]) :解压缩PKZIP中的档案或目录。[options list]可用的参数。
这些参数能让使用者在解压缩的时候有更多的选项,譬如指定变更解压缩档案的路径、指定只解压缩某些档案或不解压缩某些档案或者是将档案解压缩成字串输出(可用于readme档)。下例是一个简单的解压缩档案示例,将压缩档archive.zip内的档案解压缩至目前的目录:
<span style="font-size: 14px;">< ?PHP</span><br /> require_once('pclzip.lib.php');<br /> $archive = new PclZip('archive.zip');<br /> <br /> <br /> if ($archive->extract() == 0) {<br /> die("Error : ".$archive->errorInfo(true));<br /> }<br />?>
下例是进阶的解压缩档案使用,archive.zip中所有档案都解压缩于data/中,而特别指明在install/release中的所有档案也直接丢于data/中,而非data/install/ release:
< ?PHP<br /> include('pclzip.lib.php');<br /> $archive = new PclZip('archive.zip');<br /> if ($archive->extract(PCLZIP_OPT_PATH, 'data',<br /> PCLZIP_OPT_REMOVE_PATH, 'install/release') == 0) {<br /> die("Error : ".$archive->errorInfo(true));<br /> }<br /><p>?>
项目地址:http://www.phpconcept.net/pclzip/

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

长URL(通常用关键字和跟踪参数都混乱)可以阻止访问者。 URL缩短脚本提供了解决方案,创建了简洁的链接,非常适合社交媒体和其他平台。 这些脚本对于单个网站很有价值

在Facebook在2012年通过Facebook备受瞩目的收购之后,Instagram采用了两套API供第三方使用。这些是Instagram Graph API和Instagram Basic Display API。作为开发人员建立一个需要信息的应用程序

Laravel使用其直观的闪存方法简化了处理临时会话数据。这非常适合在您的应用程序中显示简短的消息,警报或通知。 默认情况下,数据仅针对后续请求: $请求 -

这是有关用Laravel后端构建React应用程序的系列的第二个也是最后一部分。在该系列的第一部分中,我们使用Laravel为基本的产品上市应用程序创建了一个RESTFUL API。在本教程中,我们将成为开发人员

Laravel 提供简洁的 HTTP 响应模拟语法,简化了 HTTP 交互测试。这种方法显着减少了代码冗余,同时使您的测试模拟更直观。 基本实现提供了多种响应类型快捷方式: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

PHP客户端URL(curl)扩展是开发人员的强大工具,可以与远程服务器和REST API无缝交互。通过利用Libcurl(备受尊敬的多协议文件传输库),PHP curl促进了有效的执行

您是否想为客户最紧迫的问题提供实时的即时解决方案? 实时聊天使您可以与客户进行实时对话,并立即解决他们的问题。它允许您为您的自定义提供更快的服务

2025年的PHP景观调查调查了当前的PHP发展趋势。 它探讨了框架用法,部署方法和挑战,旨在为开发人员和企业提供见解。 该调查预计现代PHP Versio的增长
