(PHP 4, PHP 5, PHP 7, PHP 8)
popen — Crée un processus de pointeur de fichier
Description
popen(string
$command
, string
$mode
): resource|false
Liste de paramètres
-
command
-
La 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. tout caractères \n
écrit ou lu du pipe sera
traduit en \r\n
.
Si ceci n'est pas désiré, le mode binaire peut être enforcé en définissant
le mode
à 'rb'
et
'wb'
, respectivement.
Valeurs de retour
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 retournera false
.
Exemples
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 vous 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 que vous puissiez lire stderr. */
$handle = popen('/path/to/executable 2>&1', 'r');
echo "'$handle'; " . gettype($handle) . "\n";
$read = fread($handle, 2096);
echo $read;
pclose($handle);
?>
Notes
Note:
Si vous souhaitez un support bidirectionnel (two-way), utilisez
la fonction proc_open().
Voir aussi
- pclose() - Ferme un processus de pointeur de fichier
- fopen() - Ouvre un fichier ou une URL
- proc_open() - Exécute une commande et ouvre les pointeurs de fichiers pour les entrées / sorties