(PECL rar >= 2.0.0)
RarEntry::getStream — Récupère le gestion de fichier pour une entrée
$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.
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().
      
   Le gestionnaire de fichier, ou FALSE si une erreur survient.
  
| Version | Description | 
|---|---|
| 3.0.0 | Support des archives RAR dont les entrées portent le même nom. | 
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);
?>