RarEntry::getStream
(PECL rar >= 2.0.0)
RarEntry::getStream — Récupère le gestion de fichier pour une entrée
Description
$password
] )Retourne le gestionnaire de fichier qui supporte les opérations de lecture. Ce gestionnaire permet la décompression à la volée de l'entrée.
Le gestionnaire ne sera pas touché par l'appel à la fonction rar_close().
Le flux résultant ne permet pas de vérifier l'intégrité des données. Par exemple, un fichier corrompu ou crypté avec une clé fausse ne sera pas détecté. Ce sera de la responsabilité du développeur d'utiliser le CRC de l'entrée pour vérifier son intégrité, s'il le souhaite.
Liste de paramètres
-
password
-
Le mot de passe à utiliser pour décrypter l'entrée. Si l'entrée n'est pas crypté, la valeur ne sera pas utilisée et peut être omise. Si ce paramètre est omis et que l'entrée est crypté, le mot de passe fourni lors de l'appel à la fonction rar_open() sera utilisé, si il a été fourni. Si un mauvais mot de passe est fourni, soit explicitement, soit implicitement via la fonction rar_open(), le flux résultant produira un affichage incorrect. Si aucun mot de passe n'est fourni alors qu'il est nécessaire, la méthode échouera et retournera
FALSE
. Vous pouvez vérifier si l'entrée est cryptée en utilisant la méthode RarEntry::isEncrypted().
Valeurs de retour
Le gestionnaire de fichier, ou FALSE
si une erreur survient.
Historique
Version | Description |
---|---|
3.0.0 | Support des archives RAR dont les entrées portent le même nom. |
Exemples
Exemple #1 Exemple avec RarEntry::getStream()
<?php $rar_file = rar_open('example.rar'); if ($rar_file === false) die("Échec lors de l'ouverture de l'archive Rar"); $entry = rar_entry_get($rar_file, 'Dir/file.txt'); if ($entry === false) die("Impossible de trouver l'entrée demandée"); $stream = $entry->getStream(); if ($stream === false) die("Échec lors de la récupération du flux."); rar_close($rar_file); //le flux est indépendant du fichier while (!feof($stream)) { $buff = fread($stream, 8192); if ($buff !== false) echo $buff; else break; //erreur fread } fclose($stream); ?>