exec
(PHP 4, PHP 5, PHP 7, PHP 8)
exec — Exécute un programme externe
Liste de paramètres
command
-
La commande à exécuter.
output
-
Si l'argument output
est présent,
alors ce tableau sera rempli par les lignes retournées par
la commande. Les espaces de début et de fin de chaîne, comme
\n
, ne seront pas inclus dans ce tableau.
Il faut noter que si ce tableau contient des
éléments, exec() ajoutera
les nouvelles lignes à la fin du tableau. Si vous ne
voulez pas que les nouveaux éléments soient
concaténés, utilisez la fonction
unset() avec ce tableau avant
de le passer à exec().
result_code
-
Si l'argument result_code
est présent
en plus du tableau output
, alors le statut
de retour d'exécution sera inscrit dans cette variable.
Valeurs de retour
La dernière ligne du résultat de la commande. Pour exécuter une commande
et obtenir le résultat sans aucun traitement, il faut utiliser la
fonction passthru().
Retourne false
en cas d'erreur.
Pour récupérer la sortie de la commande exécutée, assurez-vous de définir
et d'utiliser le paramètre output
.
Erreurs / Exceptions
Émet une alerte E_WARNING
si exec() ne peut pas
exécuter la commande command
.
Lève une exception ValueError si command
est vide ou contient des octets nuls.
Exemples
Exemple #1 Exemple avec exec()
<?php
// Affiche le nom d'utilisateur qui fait tourner le processus php/http
// (sur un système ayant "whoami" dans le chemin d'exécutables)
$output=null;
$retval=null;
exec('whoami', $output, $retval);
echo "Returned with status $retval and output:\n";
print_r($output);
?>
Résultat de l'exemple ci-dessus est similaire à :
Returned with status 0 and output:
Array
(
[0] => cmb
)
Notes
Avertissement
Si des données provenant des utilisateurs ont la permission d'être passées à cette fonction, utilisez
escapeshellarg() ou escapeshellcmd() pour s'assurer que les utilisateurs
ne peuvent pas amener le système à exécuter des commandes arbitraires.
Note:
Si un programme est démarré avec cette fonction et qu'il tourne en arrière plan, la sortie du programme doit
être redirigée vers un fichier, ou un autre flux de sortie. À défaut, PHP sera bloqué
jusqu'à la fin de l'exécution du programme.
Note:
Sur Windows exec() démarrera d'abord cmd.exe pour exécuter la commande.
Si vous voulez démarrer un programme externe sans exécuter cmd.exe utilisez proc_open()
en définissant l'option bypass_shell
.