PHPerKaigi 2025

bzopen

(PHP 4 >= 4.0.4, PHP 5, PHP 7, PHP 8)

bzopenÖffnet eine bzip2-komprimierte Datei

Beschreibung

bzopen(string|resource $file, string $mode): resource|false

Öffnet eine bzip2-Datei (.bz2) zum Lesen oder Schreiben.

Parameter-Liste

file

Name der zu öffnenden Datei, oder eine bestehende Stream-Ressource.

mode

Die Modi 'r' und 'w' werden unterstützt. Andere Werte führen dazu, daß bzopen false zurückgibt.

Rückgabewerte

Wenn das Öffnen fehlschlägt, gibt bzopen() false zurück, andernfalls wird ein Zeiger auf die geöffnete Datei zurückgegeben.

Beispiele

Beispiel #1 bzopen()-Beispiel

<?php

$file
= "/tmp/foo.bz2";
$bz = bzopen($file, "r") or die("$file konnte nicht zum Lesen geöffnet werden");

bzclose($bz);

?>

Siehe auch

add a note

User Contributed Notes 2 notes

up
1
KrazyBox
16 years ago
In some circumstances, you may want to send a bzip2 stream to the client.

To do this, you need only do:

<?php
ob_flush
();
$bz = bzopen('php://stdout', 'w');
bzwrite($bz, 'some input here');
bzclose($bz);
?>

However, please note, because you are using STDOUT, you need to ob_flush() before actually writing to the stream. Otherwise, you might be sending data before the headers, which will cause errors on both server and client ends, in most cases.

You might be able to use php://output rather than php://stdout, however in my tests (with Linux), php://output doesn't actually work - at all.
up
-1
Jille at quis dot cx dot spam dot to dot my dot devnull
16 years ago
Warning!

the example show above is _not_ working in every case!
This example will continue reading until there is no more data:

<?PHP
$bz
=bzopen('foo.bz2', 'r');
$data="";
do {
$line=bzread($bz, 8092);
if(
$line!==false)
$data.=$line;
}
while(
$line);
bzclose($bz);
?>
To Top