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

Example #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";
}
?>

Example #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";
?>

Example #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