PHPCon Poland 2024

ZipArchive::getStream

(PHP 5 >= 5.2.0, PHP 7, PHP 8, PECL zip >= 1.1.0)

ZipArchive::getStreamObtém um manipulador de arquivo para a entrada definida pelo seu nome (somente leitura)

Descrição

public ZipArchive::getStream(string $name): resource|false

Obtém um manipulador de arquivo para a entrada definida pelo seu nome. Por enquanto, suporta apenas operações de leitura.

Parâmetros

name

O nome da entrada a ser usado.

Valor Retornado

Retorna um ponteiro de arquivo (recurso) em caso de sucesso ou false em caso de falha.

Exemplos

Exemplo #1 Obter o conteúdo da entrada com fread() e armazená-lo

<?php
$contents
= '';
$z = new ZipArchive();
if (
$z->open('test.zip')) {
$fp = $z->getStream('test');
if(!
$fp) exit("failed\n");

while (!
feof($fp)) {
$contents .= fread($fp, 2);
}

fclose($fp);
file_put_contents('t',$contents);
echo
"done.\n";
}
?>

Exemplo #2 Mesmo que o exemplo anterior, mas com fopen() e o wrapper de fluxo zip

<?php
$contents
= '';
$fp = fopen('zip://' . dirname(__FILE__) . '/test.zip#test', 'r');
if (!
$fp) {
exit(
"cannot open\n");
}
while (!
feof($fp)) {
$contents .= fread($fp, 2);
}
echo
"$contents\n";
fclose($fp);
echo
"done.\n";
?>

Exemplo #3 Wrapper de fluxo e imagem, pode ser usado também com a função xml

<?php
$im
= imagecreatefromgif('zip://' . dirname(__FILE__) . '/test_im.zip#pear_item.gif');
imagepng($im, 'a.png');
?>

Veja Também

add a note

User Contributed Notes 2 notes

up
2
Sbastien
1 year ago
Here a way to handle specific files from a zip archive without full extract :

<?php

$zip_file
= '/path/to/file.zip'; // I wan to get stream a CSV files

$zip = new ZipArchive();
$zip->open($zip_file);
for (
$i = 0; $i < $zip->numFiles; $i++) { // Check file by file
$name = $zip->getNameIndex($i); // Retrieve entry name
$extension = pathinfo($name, PATHINFO_EXTENSION);
if (
$extension === 'csv') { // I want to handle csv files
$stream = $zip->getStream($name); // No stream index access before PHP 8.2
// Starting PHP 8.2 $zip->getStreamIndex() or $zip->getStreamName()
// Do stuff with $stream
// ...
}
}
up
0
oleg at andreyev dot lv
2 years ago
Keep in mind that this stream is not rewindable/seekable.
To Top