(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
= 0,$flags
= ZipArchive::FL_OVERWRITEAñade un fichero al archivo ZIP par la ruta dada.
Nota: Para una portabilidad máxima, se recomienda utilizar siempre barras hacia adelante (
/
) como separador de directorios en nombres de ficheros ZIP.
filename
La ruta del fichero a añadir.
entryname
Si corresponde, este es el nombre local dentro del archivo ZIP que reemplazará el filepath
.
start
Para la copia parcial, posición de inicio.
length
Para la copia parcial, longitud a copiar, si es 0 o -1 se utiliza todo el fichero (empezando por start
).
flags
Máscara de bits compuesta por ZipArchive::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 / 1.18.0 | Se añadio flags . |
8.3.0 / 1.22.1 | Se añadio ZipArchive::FL_OPEN_FILE_NOW . |
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.