begin process at 2008 09 06 08:41:08
1 237 664 membres
61 nouveaux aujourd'hui
14 313 membres club

Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum.
Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

EXECUTE_SYSTEM_COMMAND


Information sur la source

Catégorie :Système Source .NET ( DotNet ) Classé sous : ShellExecute, ExecuteAs, Redirection, ReturnCode, ExitCode Niveau : Débutant Date de création : 01/03/2008 Date de mise à jour : 23/03/2008 10:04:45 Vu / téléchargé: 3 694 / 155

Note :
10 / 10 - par 1 personne
10,00 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10

Commentaire sur cette source (1)
Ajouter un commentaire et/ou une note

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

  • 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;
  • }
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!
Pour les "Membres Club", vous pouvez télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !

Télécharger le zip

23 mars 2008 10:02:34 :
Rectification de l'extrait de code pour qu'il puisse être exécuté isolément.
23 mars 2008 10:04:45 :
Rectification de l'extrait de code pour qu'il puisse être utilisé seul.
  • signaler à un administrateur
    Commentaire de tmcuh le 03/03/2008 13:42:06 10/10

    Source intéressante... manque plus que les idées d'utilisations ^^

Ajouter un commentaire

Pub



Appels d'offres

CalendriCode

Septembre 2008
LMMJVSD
1234567
891011121314
15161718192021
22232425262728
2930     

Boutique

Boutique de goodies CodeS-SourceS