Execute_system_command

Description

un exemple d'exécution de Commande Système et de récupération du Code de Sortie (ExitCode) sans passer par les appels (peu élégants) au Kernel32
J'utilise les classes CSharp C# System.Diagnostics.Process et System.Diagnostics.ProcessStartInfo
Cet exemple permet aussi de capturer la sortie de la commande (redirection stdout) pour l'afficher dans un textBox multiligne,
numéroté ou pas.
On paramètre la durée du délai (timeOut) après lequel la commande sera stopppée (kill du process).
(Bien sûr dans ce cas, le code de retour en sera pas renvoyé; à la place, je retourne -1)
L'appel peut aussi utiliser le Shell, auquel cas la commande peut aussi bien être une adresse HTTP: ou n'importe quelle commande valide
dans le menu Démarrer/Exécuter de WindowsXP.
Si l'on utilise l'appel par le Shell, il n'y a pas de code de retour. On recevra toujours 0 sauf si la commande était invalide (-1).

Source / Exemple :


using System.Diagnostics;

        public static int executeCommand(string cmd, string parms, int millisecsTimeOut, bool windowed, bool shellExecute)
        {
            System.Diagnostics.ProcessStartInfo processStartInfo =
               new System.Diagnostics.ProcessStartInfo(cmd,parms); //la commande à exécuter, les paramètres. Ex: "CMD.EXE", "/C " + maCommande);
            processStartInfo.CreateNoWindow = !windowed;  //lance sans ouvrir de fenêtre ou en ouvrant une fenêtre
            processStartInfo.UseShellExecute = shellExecute; //passe ou pas par ShellExecute
            int exitCode = -1;
            System.Diagnostics.Process process = null;
            try    //lance le process et passe le bloc de paramètres            
            {
                process = System.Diagnostics.Process.Start(processStartInfo);
            }
            catch
            {
                return -1; //erreur d'exécution (commande probablement invalide)
            }
            process.WaitForExit(millisecsTimeOut);
            try
            {
                exitCode = process.ExitCode; //récupère le code de sortie (fin de la commande) si terminée
                process.Close();  //libère les ressources du processus normalement
            }
            catch  //ici la commande n'était pas terminée. Exception. On va "tuer" ce programme
            {
                process.Kill(); //tue le processus qui ne s'est pas terminé dans le temps imparti
            }
            return exitCode;
        }

Conclusion :


à partir de ces exemples, très simples, on peut aisément lancer n'importe quelle commande système (même les commandes internes de Windows
soit en utilisant l'exécution directe et CMD.EXE avec en paramètre /C suivi de la commande
soit en utilisant l'exécution par le ShellExecute et en indiquant une commande windows valide et ses paramètres, ou n'importe quelle adresse http
telle que http://vvibert.free.fr/Sigma
à vous d'inventer d'autres utilisations possibles.

Un conseil, téléchargez le zip complet, avec sa petite interface graphique, c'est plus facile à utiliser et à comprendre!

Codes Sources

Vous n'êtes pas encore membre ?

inscrivez-vous, c'est gratuit et ça prend moins d'une minute !

Les membres obtiennent plus de réponses que les utilisateurs anonymes.

Le fait d'être membre vous permet d'avoir un suivi détaillé de vos demandes et codes sources.

Le fait d'être membre vous permet d'avoir des options supplémentaires.