(PHP 4, PHP 5, PHP 7, PHP 8)
popen — Crée un processus de pointeur de fichier
Crée un processus de pointeur de fichier, exécuté en effectuant un fork
de la commande fournie par le paramètre command.
commandLa commande
mode
Le mode. Soit 'r' pour lecture, soit 'w'
pour l'écriture.
Sur Windows, popen() utilise le mode texte par défaut,
c.-à-d. tous les caractères \n écrits ou lus du pipe seront
traduits en \r\n.
Si ceci n'est pas désiré, le mode binaire peut être forcé en définissant
le mode à 'rb' et
'wb', respectivement.
Retourne un pointeur de fichier identique à celui retourné par fopen(), hormis le fait qu'il sera unidirectionnel (lecture seule, ou écriture seule), et doit être terminé par pclose(). Ce pointeur peut être utilisé avec fgets(), fgetss() et fwrite(). Lorsque le mode est 'r', le pointeur de fichier retourné équivaut au STDOUT de la commande, et lorsque le mode est 'w', le pointeur de fichier retourné équivaut au STDIN de la commande.
Si une erreur survient, la fonction retourne false.
Exemple #1 Exemple avec popen()
<?php
$handle = popen("/bin/ls", "r");
?>Si la commande à exécuter n'a pu être trouvée, une ressource valide sera retournée. Cela semble étrange, mais c'est pratique. cela permet d'accéder aux messages d'erreur qui ont été retournés par le Shell :
Exemple #2 Exemple avec popen()
<?php
error_reporting(E_ALL);
/* Ajoute une redirection pour pouvoir lire stderr. */
$handle = popen('/path/to/executable 2>&1', 'r');
echo "'$handle'; " . gettype($handle) . "\n";
$read = fread($handle, 2096);
echo $read;
pclose($handle);
?>Note:
Pour un support bidirectionnel (two-way), il convient d'utiliser la fonction proc_open().