PHP 8.4.0 RC4 available for testing

bzopen

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

bzopenOuvre un fichier compressé avec bzip2

Description

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

bzopen() ouvre un fichier bzip2 (.bz2) en écriture ou en lecture.

Liste de paramètres

file

Le nom du fichier à ouvrir ou une ressource de flux existante.

mode

Les modes 'r' (pour lecture), et 'w' (pour écriture) sont supportées. Toute autre option fera que la fonction bzopen() retournera false.

Valeurs de retour

Si l'ouverture échoue, bzopen() retourne false, sinon, il retourne un pointeur vers le fichier ouvert.

Exemples

Exemple #1 Exemple avec bzopen()

<?php

$file
= "/tmp/foo.bz2";
$bz = bzopen($file, "r") or die("Impossible d'ouvrir le fichier $file pour lecture");

bzclose($bz);

?>

Voir aussi

add a note

User Contributed Notes 2 notes

up
1
KrazyBox
15 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