(PHP 4, PHP 5, PHP 7)
popen — Crée un processus de pointeur de fichier
$command
, string $mode
)
Crée un processus de pointeur de fichier, exécuté en effectuant un fork
de la commande fournie par le paramètre command
.
command
La commande
mode
Le mode
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
.
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);
?>
Note:
Si vous souhaitez un support bidirectionnel (two-way), utilisez la fonction proc_open().
Note: Lorsque le safe mode est activé, vous pouvez uniquement exécuter des programmes qui se situent dans le dossier défini par safe_mode_exec_dir. Pour des raisons pratiques, il n'est actuellement pas permis d''avoir le composant .. dans le chemin de l'exécutable.
Lorsque le safe mode est activé, la chaîne de commande est échappée avec la fonction escapeshellcmd(). Par exemple, echo y | echo x devient echo y \| echo x.