2002-04-15 00:12:54 +00:00
|
|
|
<?xml version="1.0" encoding="iso-8859-1"?>
|
2007-06-20 22:25:43 +00:00
|
|
|
<!-- $Revision: 1.15 $ -->
|
2005-09-04 11:49:43 +00:00
|
|
|
<!-- Purpose: compression -->
|
2006-08-11 18:13:52 +00:00
|
|
|
<!-- Membership: bundled, pecl -->
|
2005-09-04 11:49:43 +00:00
|
|
|
|
2007-06-20 22:25:43 +00:00
|
|
|
<reference xml:id="ref.zip" xmlns="http://docbook.org/ns/docbook" xmlns:xlink="http://www.w3.org/1999/xlink">
|
2006-08-11 17:59:01 +00:00
|
|
|
<title>Zip File Functions</title>
|
|
|
|
<titleabbrev>Zip</titleabbrev>
|
|
|
|
|
|
|
|
<partintro>
|
2007-06-20 22:25:43 +00:00
|
|
|
<section xml:id="zip.intro">
|
2006-08-11 17:59:01 +00:00
|
|
|
&reftitle.intro;
|
|
|
|
<para>
|
2007-02-14 18:57:17 +00:00
|
|
|
This extension enables you to transparently read or write ZIP compressed
|
2006-08-11 17:59:01 +00:00
|
|
|
archives and the files inside them.
|
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
2007-06-20 22:25:43 +00:00
|
|
|
<section xml:id="zip.requirements">
|
2006-08-11 17:59:01 +00:00
|
|
|
&reftitle.required;
|
2007-06-20 22:25:43 +00:00
|
|
|
<section xml:id="zip.requirements.old">
|
2007-02-14 18:57:17 +00:00
|
|
|
<title>PHP 4</title>
|
2006-08-11 17:59:01 +00:00
|
|
|
<para>
|
2007-06-20 22:25:43 +00:00
|
|
|
The bundled PHP 4 version requires <link xlink:href="&url.zziplib;">ZZIPlib</link>,
|
2007-02-14 18:57:17 +00:00
|
|
|
by Guido Draheim, version 0.10.6 or later
|
2003-10-24 16:21:40 +00:00
|
|
|
</para>
|
|
|
|
</section>
|
2006-08-11 17:27:59 +00:00
|
|
|
|
2007-06-20 22:25:43 +00:00
|
|
|
<section xml:id="zip.requirements.new">
|
2007-02-15 08:12:20 +00:00
|
|
|
<title>PHP 5.2.0 or later</title>
|
2002-07-20 12:26:41 +00:00
|
|
|
<para>
|
2007-06-20 22:25:43 +00:00
|
|
|
This extension uses the functions of <link xlink:href="&url.zlib;">zlib</link>
|
2007-02-14 18:57:17 +00:00
|
|
|
by Jean-loup Gailly and Mark Adler.
|
2002-04-15 00:12:54 +00:00
|
|
|
</para>
|
2003-10-24 16:21:40 +00:00
|
|
|
</section>
|
2006-08-11 17:59:01 +00:00
|
|
|
</section>
|
|
|
|
|
|
|
|
&reference.zip.configure;
|
|
|
|
|
2007-06-20 22:25:43 +00:00
|
|
|
<section xml:id="zip.configuration">
|
2006-08-11 17:59:01 +00:00
|
|
|
&reftitle.runtime;
|
|
|
|
&no.config;
|
|
|
|
</section>
|
|
|
|
|
2007-06-20 22:25:43 +00:00
|
|
|
<section xml:id="zip.resources">
|
2006-08-11 17:59:01 +00:00
|
|
|
&reftitle.resources;
|
|
|
|
<para>
|
|
|
|
There are two resource types used in the Zip module. The first one
|
|
|
|
is the Zip directory for the Zip archive, the second Zip Entry for
|
|
|
|
the archive entries.
|
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
|
|
|
&reference.zip.constants;
|
|
|
|
|
2007-06-20 22:25:43 +00:00
|
|
|
<section xml:id="zip.examples">
|
2006-08-11 17:59:01 +00:00
|
|
|
&reftitle.examples;
|
|
|
|
<example>
|
|
|
|
<title>Create a Zip archive</title>
|
|
|
|
<programlisting role="php">
|
2006-08-11 17:27:59 +00:00
|
|
|
<![CDATA[
|
|
|
|
<?php
|
|
|
|
|
|
|
|
$zip = new ZipArchive();
|
|
|
|
$filename = "./test112.zip";
|
|
|
|
|
|
|
|
if ($zip->open($filename, ZIPARCHIVE::CREATE)!==TRUE) {
|
|
|
|
exit("cannot open <$filename>\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
$zip->addFromString("testfilephp.txt" . time(), "#1 This is a test string added as testfilephp.txt.\n");
|
|
|
|
$zip->addFromString("testfilephp2.txt" . time(), "#2 This is a test string added as testfilephp2.txt.\n");
|
|
|
|
$zip->addFile($thisdir . "/too.php","/testfromfile.php");
|
|
|
|
echo "numfiles: " . $zip->numFiles . "\n";
|
|
|
|
echo "status:" . $zip->status . "\n";
|
|
|
|
$zip->close();
|
|
|
|
?>
|
|
|
|
]]>
|
2006-08-11 17:59:01 +00:00
|
|
|
</programlisting>
|
|
|
|
</example>
|
|
|
|
<example>
|
|
|
|
<title>Dump the archive details and listing</title>
|
|
|
|
<programlisting role="php">
|
2006-08-11 17:27:59 +00:00
|
|
|
<![CDATA[
|
|
|
|
<?php
|
|
|
|
$za = new ZipArchive();
|
|
|
|
|
|
|
|
$za->open('test_with_comment.zip');
|
|
|
|
print_r($za);
|
|
|
|
var_dump($za);
|
|
|
|
echo "numFiles: " . $za->numFiles . "\n";
|
|
|
|
echo "status: " . $za->status . "\n";
|
|
|
|
echo "statusSys: " . $za->statusSys . "\n";
|
|
|
|
echo "filename: " . $za->filename . "\n";
|
|
|
|
echo "comment: " . $za->comment . "\n";
|
|
|
|
|
|
|
|
for ($i=0; $i<$za->numFiles;$i++) {
|
|
|
|
echo "index: $i\n";
|
|
|
|
print_r($za->statIndex($i));
|
|
|
|
}
|
|
|
|
echo "numFile:" . $za->numFiles . "\n";
|
|
|
|
?>
|
|
|
|
]]>
|
2006-08-11 17:59:01 +00:00
|
|
|
</programlisting>
|
|
|
|
</example>
|
|
|
|
<example>
|
|
|
|
<title>Zip stream wrapper, read an OpenOffice meta info</title>
|
|
|
|
<programlisting role="php">
|
2006-08-11 17:27:59 +00:00
|
|
|
<![CDATA[
|
|
|
|
<?php
|
|
|
|
$reader = new XMLReader();
|
|
|
|
|
|
|
|
$reader->open('zip://' . dirname(__FILE__) . '/test.odt#meta.xml');
|
|
|
|
$odt_meta = array();
|
|
|
|
while ($reader->read()) {
|
|
|
|
if ($reader->nodeType == XMLREADER::ELEMENT) {
|
|
|
|
$elm = $reader->name;
|
|
|
|
} else {
|
|
|
|
if ($reader->nodeType == XMLREADER::END_ELEMENT && $reader->name == 'office:meta') {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
if (!trim($reader->value)) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
$odt_meta[$elm] = $reader->value;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
print_r($odt_meta);
|
|
|
|
?>
|
|
|
|
]]>
|
2006-08-11 17:59:01 +00:00
|
|
|
</programlisting>
|
|
|
|
</example>
|
|
|
|
<para>
|
|
|
|
This example uses the old API (PHP 4), it opens a ZIP file
|
|
|
|
archive, reads each file in the archive and prints out its
|
|
|
|
contents. The <filename>test2.zip</filename> archive used in this
|
|
|
|
example is one of the test archives in the ZZIPlib source
|
|
|
|
distribution.
|
|
|
|
</para>
|
|
|
|
<example>
|
|
|
|
<title>Zip Usage Example</title>
|
|
|
|
<programlisting role="php">
|
2002-04-15 00:12:54 +00:00
|
|
|
<![CDATA[
|
|
|
|
<?php
|
|
|
|
|
|
|
|
$zip = zip_open("/tmp/test2.zip");
|
|
|
|
|
|
|
|
if ($zip) {
|
|
|
|
while ($zip_entry = zip_read($zip)) {
|
2003-10-24 16:21:40 +00:00
|
|
|
echo "Name: " . zip_entry_name($zip_entry) . "\n";
|
|
|
|
echo "Actual Filesize: " . zip_entry_filesize($zip_entry) . "\n";
|
|
|
|
echo "Compressed Size: " . zip_entry_compressedsize($zip_entry) . "\n";
|
|
|
|
echo "Compression Method: " . zip_entry_compressionmethod($zip_entry) . "\n";
|
2002-04-15 00:12:54 +00:00
|
|
|
|
|
|
|
if (zip_entry_open($zip, $zip_entry, "r")) {
|
2003-10-24 16:21:40 +00:00
|
|
|
echo "File Contents:\n";
|
2002-04-15 00:12:54 +00:00
|
|
|
$buf = zip_entry_read($zip_entry, zip_entry_filesize($zip_entry));
|
|
|
|
echo "$buf\n";
|
|
|
|
|
|
|
|
zip_entry_close($zip_entry);
|
|
|
|
}
|
|
|
|
echo "\n";
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
zip_close($zip);
|
|
|
|
|
|
|
|
}
|
|
|
|
?>
|
|
|
|
]]>
|
2006-08-11 17:59:01 +00:00
|
|
|
</programlisting>
|
|
|
|
</example>
|
|
|
|
</section>
|
|
|
|
</partintro>
|
|
|
|
|
|
|
|
&reference.zip.functions;
|
2002-04-15 00:12:54 +00:00
|
|
|
|
|
|
|
</reference>
|
|
|
|
<!-- Keep this comment at the end of the file
|
|
|
|
Local variables:
|
|
|
|
mode: sgml
|
|
|
|
sgml-omittag:t
|
|
|
|
sgml-shorttag:t
|
|
|
|
sgml-minimize-attributes:nil
|
|
|
|
sgml-always-quote-attributes:t
|
|
|
|
sgml-indent-step:1
|
|
|
|
sgml-indent-data:t
|
|
|
|
indent-tabs-mode:nil
|
|
|
|
sgml-parent-document:nil
|
|
|
|
sgml-default-dtd-file:"../../../manual.ced"
|
|
|
|
sgml-exposed-tags:nil
|
|
|
|
sgml-local-catalogs:nil
|
|
|
|
sgml-local-ecat-files:nil
|
|
|
|
End:
|
|
|
|
vim600: syn=xml fen fdm=syntax fdl=2 si
|
|
|
|
vim: et tw=78 syn=sgml
|
|
|
|
vi: ts=1 sw=1
|
|
|
|
-->
|