(PHP 5 >= 5.2.0, PHP 7, PHP 8, PECL zip >= 1.1.0)
ZipArchive::addFile — Añade un fichero al archivo ZIP para la ruta dada
$filepath,$entryname = "",$start = 0,$length = ZipArchive::LENGTH_TO_END,$flags = ZipArchive::FL_OVERWRITEAñade un fichero al archivo ZIP par la ruta dada.
Nota: Para una portabilidad máxima, se recomienda siempre utilizar barras oblicuas (
/) como separador de directorio en los nombres de archivos zip.
filenameentrynamefilepath.
startlengthZipArchive::LENGTH_TO_END (0) se usa el tamaño del archivo,
si ZipArchive::LENGTH_UNCHECKED se usa todo el archivo
(comenzando desde start).
flagsZipArchive::FL_OVERWRITE,
ZipArchive::FL_ENC_GUESS,
ZipArchive::FL_ENC_UTF_8,
ZipArchive::FL_ENC_CP437,
ZipArchive::FL_OPEN_FILE_NOW.
El comportamiento de estas constantes se describe en
la página de constantes ZIP.
| Versión | Descripción |
|---|---|
| 8.0.0, PECL zip 1.18.0 |
Se añadio flags.
|
| 8.3.0, PECL zip 1.22.1 |
Se añadio ZipArchive::FL_OPEN_FILE_NOW.
|
| 8.3.0, PECL zip 1.22.2 |
ZipArchive::LENGTH_TO_END and ZipArchive::LENGTH_UNCHECKED were added.
|
Este ejemplo abre un archivo ZIP test.zip y añade el fichero /path/to/index.txt. como newname.txt.
Ejemplo #1 Abrir y extraer
<?php
$zip = new ZipArchive;
if ($zip->open('test.zip') === TRUE) {
$zip->addFile('/path/to/index.txt', 'newname.txt');
$zip->close();
echo 'ok';
} else {
echo 'failed';
}
?>Nota: Cuando un fichero es añadido al archivo, PHP bloqueará el fichero. El bloqueo se desbloqueará cuando el objeto ZipArchive finalice, ya sea a través de ZipArchive::close() o el objeto ZipArchive sea destruido. Esto puede impedir que se pueda eliminar el archivo que se está añadiendo hasta después de que el bloqueo haya sido liberado.