system

(PHP 3, PHP 4 , PHP 5)

system --  Exécute un programme externe et affiche le résultat

Description

string system ( string command [, int &return_var] )

system() est la version PHP de la fonction C qui exécute la commande command et retourne le résultat. Si une variable est fournie comme second argument return_var, alors le code de statut de la commande y sera placé.

Avertissement

Si vous allez passer des données provenant de l'utilisateur à cette fonction, vous devez utiliser escapeshellarg() ou escapeshellcmd() pour être sûrs qu'ils n'endommagent pas le système en exécutant des commandes arbitraires.

Note : Si vous démarrez un programme en utilisant cette fonction et que vous voulez le laisser tourner en arrière plan, vous devez vous assurer que la sortie du programme est redirigée vers un fichier, ou un autre flux de sortie, sinon PHP attendra jusqu'à la fin de l'exécution du programme.

system() retourne la dernière ligne du retour, en cas de succès, et FALSE en cas d'échec.

Si vous devez exécuter une commande et récupérer tout le résultat sans aucune intervention, utilisez la fonction passthru().

Exemple 1. Exemple avec system()

<?php
echo '<pre>';

// Affiche le résultat de la commande "ls" et retourne
// la dernière lignes dans $last_line. Stocke la valeur retournée
// par la commande shelle dans $retval.
$last_line = system('ls', $retval);

// Affichage d'autres informations
echo '
</pre>
<hr />La dernière ligne lue : '
. $last_line . '
<hr />Valeur retournée : '
. $retval;
?>

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.

Avertissement

Lorsque le safe mode est activé, tous les mots suivants la première instruction de la commande sont traités comme un seul argument. Par exemple, echo y | echo x devient echo "y | echo x".

Voir aussi exec(), pcntl_exec(), passthru(), popen(), escapeshellcmd() et les opérateurs de backtick.