(PHP >= 8.0.0, PECL zip >= 1.18.0)
ZipArchive::replaceFile — Reemplaza fichero en el archivo ZIP con una ruta determinada
$filepath
,$index
,$start
= 0,$length
= ZipArchive::LENGTH_TO_END,$flags
= 0Reemplaza fichero en el archivo ZIP con una ruta determinada.
Nota: Para una portabilidad máxima, se recomienda utilizar siempre barras hacia adelante (
/
) como separador de directorios en nombres de ficheros ZIP.
filepath
La ruta del archivo a añadir.
index
El índice del archivo a reemplazar, su nombre no ha cambiado.
start
Para la copia parcial, posición de inicio.
length
Para copia parcial, longitud a copiar,
si ZipArchive::LENGTH_TO_END
(0) se usa el tamaño del archivo,
si ZipArchive::LENGTH_UNCHECKED
se usa todo el archivo
(comenzando desde 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.3.0, PECL zip 1.22.1 |
Se añadio ZipArchive::FL_OPEN_FILE_NOW .
|
8.3.0, PECL zip 1.22.2 |
Se añadieron ZipArchive::LENGTH_TO_END y ZipArchive::LENGTH_UNCHECKED .
|
Este ejemplo abre un archivo ZIP test.zip y sustituye la entrada del índice 1 con /path/to/index.txt.
Ejemplo #1 Abrir y reemplazar
<?php
$zip = new ZipArchive;
if ($zip->open('test.zip') === TRUE) {
$zip->replaceFile('/path/to/index.txt', 1);
$zip->close();
echo 'ok';
} else {
echo 'failed';
}
?>