proc_nice
<<<
proc_open proc_terminate
>>>

8.31 Exécution de programmes externes
8 Référence des fonctions
 Manuel PHP

Introduction
Pré-requis
Installation
Configuration à l'exécution
Types de ressources
Constantes pré-définies
Voir aussi
escapeshellarg
escapeshellcmd
exec
passthru
proc_close
proc_get_status
proc_nice
->proc_open
proc_terminate
shell_exec
system

8.31.15 proc_open() Exécute une commande et ouvre les pointeurs de fichiers pour les entrées sorties

[ Exemples avec proc_open ]   PHP 4 >= 4.3.0, PHP 5

resource  proc_open ( string   cmd , array   descriptorspec , array   pipes , string   cwd , array   env , array   other_options )

proc_open est similaire à popen mais fournit un plus grand degré de contrôle sur l'exécution du programme. cmd est la commande qui doit être exécutée par le Shell. descriptorspec est un tableau indexé, dont les clés représentent le numéro de descripteur et la valeur la méthode avec laquelle PHP va passer ce descripteur au processus fils. pipes recevra un tableau indexé de pointeurs de fichiers qui correspondent aux sorties dans PHP de tous les pipes qui sont créés. La valeur retournée est une ressource qui représente le processus. Il faudra la détruire avec la fonction proc_close lorsque vous aurez fini.

Exemple avec proc_open

<?php
$descriptorspec
= array(
   
0 => array("pipe", "r"),  // stdin est un pipe où le processus va lire
   
1 => array("pipe", "w"),  // stdout est un pipe où le processus va écrire
   
2 => array("file", "/tmp/error-output.txt", "a"), // stderr est un fichier
);
$process = proc_open("php", $descriptorspec, $pipes);
if (
is_resource($process)) {
    
// $pipes ressemble à :
    // 0 => fichier accessible en écriture, connecté à l'entrée standard du processus fils
    // 1 => fichier accessible en lecture, connecté à la sortie standard du processus fils
    // Toute erreur sera ajoutée au fichier /tmp/error-output.txt

    
fwrite($pipes[0], "<?php echo     \"Bonjour le monde!\"; ?>");
    
fclose($pipes[0]);

    while(!
feof($pipes[1])) {
        echo
fgets($pipes[1], 1024);
    }
    
fclose($pipes[1]);
    
// Il est important que vous fermiez les pipes avant d'appeler
    // proc_close() afin d'éviter un verrouillage.
    
$return_value = proc_close($process);

    echo
"La commande a retourné $return_value\n";
}
?>

PHP 5RC2 introduit le support pty pour les systèmes avec Unix98 ptys. Cela permet à votre script d'interagir avec des applications qui s'attendent à dialoguer avec un terminal. Un pty fonctionne comme un pipe, mais est bi-directionnel : il n'y a pas besoin de spécifier de mode lecture ou écriture. L'exemple ci-dessous montre comment utiliser un pty. Notez que tous les pointeurs de fichier ne doivent pas nécessairement dialoguer avec le pty. Notez aussi que seul un pty est créé, même si pty est spécifié 3 fois. Dans les futures versions de PHP il sera possible de faire plus que simplement lire et écrire dans un pty.


<?php
// Crée un pseudo terminal pour le processus fils
$descriptorspec = array(
   
0 => array("pty"),
   
1 => array("pty"),
   
2 => array("pty")
);
$process = proc_open("cvs -d:pserver:cvsread@cvs.php.net:/repository login", $descriptorspec, $pipes);
if (
is_resource($process)) {
   
// Travaille sur la documentation PHP ici
}
?>

Les numéros de descripteurs de fichiers de descriptorspec ne sont pas limités à 0, 1 et 2 : vous pouvez spécifier n'importe quel numéro de descripteur valide, et il sera passé au processus fils. Cela permettra à votre script d'inter opérer avec d'autres scripts, et d'être exécuté comme "co-processus". En particulier, c'est très pratique pour passer des mots de passes à des programmes comme PGP, GPG et openssl, avec une méthode très protégée. C'est aussi pratique pour lire des informations de statut fournies par ces programmes, sur des descripteurs auxiliaires.

Note

Compatibilité Windows : les descripteurs au-delà de 2 (stderr) sont accessibles au processus fils, sous la forme de pointeurs héritables, mais comme l'architecture Windows n'associe pas de nombre aux descripteurs de bas niveau, le processus fils n'a (actuellement) aucun moyen d'y accéder. Stdin, stdout et stderr fonctionnent comme d'habitude.

Note

Si vous n'avez besoin que d'un processus uni-directionnel, popen sera plus pratique, car plus simple à utiliser.

Voir aussi stream_select , exec , system , passthru , popen , escapeshellcmd et les opérateurs backtick .

<< proc_open >>
proc_nice Exécution de programmes externes proc_terminate