Accueil > > > [.NET2] OBTENIR LES PROCESSUS ACTIFS DE TOUS LES COMPTES
[.NET2] OBTENIR LES PROCESSUS ACTIFS DE TOUS LES COMPTES
Information sur la source
Description
Par l'intermédiaire d'un service Windows je devais surveiller toute les x secondes si un processus tourné toujours. Hors mon service s'éxecutant sous le compte LocalSystem, il m'était impossible de voir les processus tournant entre autres sur le compte de l'utilisateur courant. Après plusieurs essais via différentes approches par API, j'ai fini par découvrir dans la précieuse MSDN la fonction WTSEnumerateProcesses. Et la c'est le miracle.... Ma démo vous montre donc comment utiliser cette fonction et ainsi obtenir la liste de tout les processus actifs tout comptes confondus + quelques infos basics sur ceux-ci. Voici un extrait de la classe de wrapper.
Source
- #region 'Variables'
-
- private static bool _HasGettedProcesses;
- private static List<ProcessInfo> _ProcessInfoCollection = new List<ProcessInfo>();
- private static string _MatchProcessName;
- private static int _MatchProcessID;
-
- #endregion
-
-
- #region 'Méthodes'
-
- /// <summary>
- /// Récupére les processus de tout les comptes.
- /// </summary>
- /// <returns>Un tableau d'objet ProcessInfo</returns>
- public static ProcessInfo[] GetAllAccountProcesses()
- {
- List<ProcessInfo> piList = new List<ProcessInfo>(); //Collection recevant les objets ProcessInfo
- IntPtr ptWTSPI = IntPtr.Zero; //Pointeur sur l'adresse mémoire du 1er bloc de données WTS_PROCESS_INFO
- int iCount = -1; //Nombre de processus
-
- //Obtient l'adresse du 1er bloc de données WTS_PROCESS_INFO + nombre de processus
- bool bret = WTSEnumerateProcesses((IntPtr)WTS_CURRENT_SERVER_HANDLE, 0, 1, ref ptWTSPI, ref iCount);
-
- //Si tout va bien
- if (bret)
- {
- //Itération sur l'ensemble des processus.
- for (int i = 0; i < iCount; i++)
- {
- WTS_PROCESS_INFO PrcInfo = new WTS_PROCESS_INFO(); //Nouvelle instance WTS_PROCESS_INFO recevant le bloc de données
-
- //Récupération des données du bloc à l'adresse du pointeur.
- PrcInfo = (WTS_PROCESS_INFO)Marshal.PtrToStructure(ptWTSPI, typeof(WTS_PROCESS_INFO));
-
- int iPID = PrcInfo.ProcessId; //ID du processus
- int iPSession = PrcInfo.SessionId; //ID de la session
- string szAccount = "", szDomain = ""; //Compte et domaine du SID
- SID_NAME_USE sidCat = new SID_NAME_USE(); //Type du SID
-
- //Récupération du nom du processus.
- string szProcessName = Marshal.PtrToStringAuto(PrcInfo.pProcessName);
-
- //Récupération du compte + domaine + type du SID.
- InfoFromSID(PrcInfo.pUserSid, ref szAccount, ref szDomain, ref sidCat);
-
- //Ajoute à la collection un objet ProcessInfo contenant les infos précédentes.
- piList.Add(new ProcessInfo(iPID, iPSession, szProcessName, szAccount, szDomain, sidCat.ToString()));
-
- //Avance le pointeur vers l'adresse du bloc de données suivant.
- ptWTSPI = (IntPtr)(ptWTSPI.ToInt32() + Marshal.SizeOf(typeof(WTS_PROCESS_INFO)));
- }
- }
-
- //Libère la mémoire allouée
- WTSFreeMemory(ptWTSPI);
-
- //Remplie la collection globale
- _ProcessInfoCollection = piList;
-
- //Flag à true indiquant que la liste à été récupérer au moins une fois
- _HasGettedProcesses = true;
-
- //Retourne un tableau ProcessInfo
- return piList.ToArray();
- }
-
- /// <summary>
- /// Récupère les informations sur un processus à partir de son nom.
- /// </summary>
- /// <param name="processname">Nom du processus.</param>
- /// <returns>Objet ProcessInfo.</returns>
- public static ProcessInfo RetrieveProcessInfo(string processname)
- {
- if (!_HasGettedProcesses)
- GetAllAccountProcesses();
-
- _MatchProcessName = processname;
-
- return _ProcessInfoCollection.Find(MatchInfoFromProcessName);
- }
-
- /// <summary>
- /// Récupère les informations sur un processus à partir de son PID.
- /// </summary>
- /// <param name="processname">PID du processus.</param>
- /// <returns>Objet ProcessInfo.</returns>
- public static ProcessInfo RetrieveProcessInfo(int pid)
- {
- //Si pas encore récupéré la liste des processus
- if (!_HasGettedProcesses)
- GetAllAccountProcesses();
-
- _MatchProcessID = pid;
-
- return _ProcessInfoCollection.Find(MatchInfoFromPID);
- }
-
- #endregion
-
-
- #region 'Méthodes privées'
-
- /// <summary>
- /// Cherche l'objet ProcessInfo suivant son nom de processus.
- /// </summary>
- /// <param name="pi">Objet ProcessInfo de recherche.</param>
- /// <returns>True si trouvé; False si non.</returns>
- private static bool MatchInfoFromProcessName(ProcessInfo pi)
- {
- if (pi.ProcessName.Equals(_MatchProcessName))
- return true;
- else
- return false;
- }
-
- /// <summary>
- /// Cherche l'objet ProcessInfo suivant son PID.
- /// </summary>
- /// <param name="pi">Objet ProcessInfo de recherche.</param>
- /// <returns>True si trouvé; False si non.</returns>
- private static bool MatchInfoFromPID(ProcessInfo pi)
- {
- if (pi.Pid.Equals(_MatchProcessID))
- return true;
- else
- return false;
- }
-
- /// <summary>
- /// Obtient des infos sur un SID
- /// </summary>
- /// <param name="SID">Pointeur SID.</param>
- /// <param name="account">Retourne le nom du compte.</param>
- /// <param name="domain">Retourne le domaine.</param>
- ///<param name="category">Retourne le type du SID.</param>
- private static void InfoFromSID(IntPtr SID, ref string account, ref string domain, ref SID_NAME_USE category)
- {
- //Recevra le compte et le domaine.
- StringBuilder szbName = new StringBuilder();
- StringBuilder szbDomain = new StringBuilder();
-
- //Longeur des chaines retournées.
- int iSizeName = 0;
- int iSizeDomain = 0;
-
- //Recevra le type de SID.
- SID_NAME_USE sidUse = new SID_NAME_USE();
-
- //1er appel afin d'obtenir la longeur des chaines de caractères du compte et du domaine.
- bool bret = LookupAccountSid(null, SID, szbName, ref iSizeName, szbDomain, ref iSizeDomain, out sidUse);
-
- //Nouvelle instances des StringBuilder dimensionnées.
- szbName = new StringBuilder(iSizeName);
- szbDomain = new StringBuilder(iSizeDomain);
-
- //2nd appel pour remplir szbName, szbDomain et sidUse
- bret = LookupAccountSid(null, SID, szbName, ref iSizeName, szbDomain, ref iSizeDomain, out sidUse);
-
- //Retourne les valeurs
- account = szbName.ToString();
- domain = szbDomain.ToString();
- category = sidUse;
- }
-
- #endregion
#region 'Variables'
private static bool _HasGettedProcesses;
private static List<ProcessInfo> _ProcessInfoCollection = new List<ProcessInfo>();
private static string _MatchProcessName;
private static int _MatchProcessID;
#endregion
#region 'Méthodes'
/// <summary>
/// Récupére les processus de tout les comptes.
/// </summary>
/// <returns>Un tableau d'objet ProcessInfo</returns>
public static ProcessInfo[] GetAllAccountProcesses()
{
List<ProcessInfo> piList = new List<ProcessInfo>(); //Collection recevant les objets ProcessInfo
IntPtr ptWTSPI = IntPtr.Zero; //Pointeur sur l'adresse mémoire du 1er bloc de données WTS_PROCESS_INFO
int iCount = -1; //Nombre de processus
//Obtient l'adresse du 1er bloc de données WTS_PROCESS_INFO + nombre de processus
bool bret = WTSEnumerateProcesses((IntPtr)WTS_CURRENT_SERVER_HANDLE, 0, 1, ref ptWTSPI, ref iCount);
//Si tout va bien
if (bret)
{
//Itération sur l'ensemble des processus.
for (int i = 0; i < iCount; i++)
{
WTS_PROCESS_INFO PrcInfo = new WTS_PROCESS_INFO(); //Nouvelle instance WTS_PROCESS_INFO recevant le bloc de données
//Récupération des données du bloc à l'adresse du pointeur.
PrcInfo = (WTS_PROCESS_INFO)Marshal.PtrToStructure(ptWTSPI, typeof(WTS_PROCESS_INFO));
int iPID = PrcInfo.ProcessId; //ID du processus
int iPSession = PrcInfo.SessionId; //ID de la session
string szAccount = "", szDomain = ""; //Compte et domaine du SID
SID_NAME_USE sidCat = new SID_NAME_USE(); //Type du SID
//Récupération du nom du processus.
string szProcessName = Marshal.PtrToStringAuto(PrcInfo.pProcessName);
//Récupération du compte + domaine + type du SID.
InfoFromSID(PrcInfo.pUserSid, ref szAccount, ref szDomain, ref sidCat);
//Ajoute à la collection un objet ProcessInfo contenant les infos précédentes.
piList.Add(new ProcessInfo(iPID, iPSession, szProcessName, szAccount, szDomain, sidCat.ToString()));
//Avance le pointeur vers l'adresse du bloc de données suivant.
ptWTSPI = (IntPtr)(ptWTSPI.ToInt32() + Marshal.SizeOf(typeof(WTS_PROCESS_INFO)));
}
}
//Libère la mémoire allouée
WTSFreeMemory(ptWTSPI);
//Remplie la collection globale
_ProcessInfoCollection = piList;
//Flag à true indiquant que la liste à été récupérer au moins une fois
_HasGettedProcesses = true;
//Retourne un tableau ProcessInfo
return piList.ToArray();
}
/// <summary>
/// Récupère les informations sur un processus à partir de son nom.
/// </summary>
/// <param name="processname">Nom du processus.</param>
/// <returns>Objet ProcessInfo.</returns>
public static ProcessInfo RetrieveProcessInfo(string processname)
{
if (!_HasGettedProcesses)
GetAllAccountProcesses();
_MatchProcessName = processname;
return _ProcessInfoCollection.Find(MatchInfoFromProcessName);
}
/// <summary>
/// Récupère les informations sur un processus à partir de son PID.
/// </summary>
/// <param name="processname">PID du processus.</param>
/// <returns>Objet ProcessInfo.</returns>
public static ProcessInfo RetrieveProcessInfo(int pid)
{
//Si pas encore récupéré la liste des processus
if (!_HasGettedProcesses)
GetAllAccountProcesses();
_MatchProcessID = pid;
return _ProcessInfoCollection.Find(MatchInfoFromPID);
}
#endregion
#region 'Méthodes privées'
/// <summary>
/// Cherche l'objet ProcessInfo suivant son nom de processus.
/// </summary>
/// <param name="pi">Objet ProcessInfo de recherche.</param>
/// <returns>True si trouvé; False si non.</returns>
private static bool MatchInfoFromProcessName(ProcessInfo pi)
{
if (pi.ProcessName.Equals(_MatchProcessName))
return true;
else
return false;
}
/// <summary>
/// Cherche l'objet ProcessInfo suivant son PID.
/// </summary>
/// <param name="pi">Objet ProcessInfo de recherche.</param>
/// <returns>True si trouvé; False si non.</returns>
private static bool MatchInfoFromPID(ProcessInfo pi)
{
if (pi.Pid.Equals(_MatchProcessID))
return true;
else
return false;
}
/// <summary>
/// Obtient des infos sur un SID
/// </summary>
/// <param name="SID">Pointeur SID.</param>
/// <param name="account">Retourne le nom du compte.</param>
/// <param name="domain">Retourne le domaine.</param>
///<param name="category">Retourne le type du SID.</param>
private static void InfoFromSID(IntPtr SID, ref string account, ref string domain, ref SID_NAME_USE category)
{
//Recevra le compte et le domaine.
StringBuilder szbName = new StringBuilder();
StringBuilder szbDomain = new StringBuilder();
//Longeur des chaines retournées.
int iSizeName = 0;
int iSizeDomain = 0;
//Recevra le type de SID.
SID_NAME_USE sidUse = new SID_NAME_USE();
//1er appel afin d'obtenir la longeur des chaines de caractères du compte et du domaine.
bool bret = LookupAccountSid(null, SID, szbName, ref iSizeName, szbDomain, ref iSizeDomain, out sidUse);
//Nouvelle instances des StringBuilder dimensionnées.
szbName = new StringBuilder(iSizeName);
szbDomain = new StringBuilder(iSizeDomain);
//2nd appel pour remplir szbName, szbDomain et sidUse
bret = LookupAccountSid(null, SID, szbName, ref iSizeName, szbDomain, ref iSizeDomain, out sidUse);
//Retourne les valeurs
account = szbName.ToString();
domain = szbDomain.ToString();
category = sidUse;
}
#endregion
Conclusion
Commentaires, notes merci de juger :)
Bon dév.
Historique
- 14 septembre 2006 21:39:56 :
- Restructuration de la source (utilisation des classes)
Sources du même auteur
Sources de la même categorie
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
Boucle des messages de processus [ par bob94700 ]
Bonjour, Je souhaiterais savoir s'il est possible de :- envoyer des messages (ou des séquences de touches) à un processus donné- détecter les messag
Retrouvé le processus actif [ par bob94700 ]
Bonjour, Je chercher à retrouver le programme actuellement actif (la fenètre qui a le focus). Pour cela, j'ai pu utiliser la fonction de l'API : Get
Status de fichier [ par SharpMao ]
Salut à tous,Est-ce que quelqu'un sait si il y a un moyen de savoir si un fichier est actuellement ouvert en écriture par un autre processus? Je m'exp
[c#]Detection processus [ par karshnod ]
Bonjour,Est il possible de savoir si une application est deja lancé, afin qu'on ne puisse la lancer 2 fois ?merci
la classe Musique [ par Online ]
Voila un nouveau petit probleme.J'ai implémenté la classe Musique dans mon application Pour rappelil se trouve que j'ai aussi un tagger et que des que
Appeler 2 processus 16 bits dans une meme fenetre dos [ par actif95 ]
Bonsoir,mon problème est le suivant :j'ai besoin d'exécuter 2 processus 16 bits dans une même fenetre dos,le 1er étant appelé une seule fois (nécessai
lancer un processus en arriere plan en C# [ par defflava ]
je veux réaliser un programme qui permet de lancer un processus permanenet en arriere plan qui detecte le changement dans un fichier texte. le progra
utilisation cpu par processus [ par Adidas2 ]
Salut tous le mondeJe cherche à obtenir l'utilisation CPU de chaque processus lancé quelqu'un aurait une idée de la fonction à utiliser svp ?Langage :
nouveau processus + arguments [ par shiva54 ]
Bonjour,Je cherche à lancer un processus et à lui passer des arguments.Tout d'abord il faut savoir que le programme accept des arguments.Mon problème
Appel de méthode d'un processus [ par SharpMao ]
Hello,Voici mon probème : J'ai un service Web qui doit faire des opérations longues. J'aimerais pouvoir créer un processus indépendant, et que le serv
|
Derniers Blogs
UNE JOLIE-HORLOGE ET PAS QU'UN PEU !UNE JOLIE-HORLOGE ET PAS QU'UN PEU ! par neodante
Pour les possesseurs d'iPhone, ça y est Bijin Tokei - qui se traduit littéralement en Français par " Jolie Horloge " - est arrivé et GRATUITEMENT s'il vous plaît ! Après la version Tokyo, Hokkaido, night club, racing, Gal, "pour les mademoiselles'", . voi...
Cliquez pour lire la suite de l'article par neodante TECHDAYS PARIS 2010 : CONNECTEZ VOS DONNéES à SHAREPOINT 2010 AVEC LES BUSINESS CONNECTIVITY SERVICESTECHDAYS PARIS 2010 : CONNECTEZ VOS DONNéES à SHAREPOINT 2010 AVEC LES BUSINESS CONNECTIVITY SERVICES par ROMELARD Fabrice
Animé par: Gaetan Bouveret et Julien Chomarat Business Connectivity Services (BCS) est dans SharePoint 2010 la version 2 de Business Data Catalog (BDC dans SharePoint 2007). Il s'agit de la solution permettant de visualiser des données provenan...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice [DIVERS] SUIVRE VOS SéRIES PRéFéRéS SUR LA TOILE[DIVERS] SUIVRE VOS SéRIES PRéFéRéS SUR LA TOILE par orion
Comme de nombreux geek, je suis un grand amateur de série TV et je rate régulièrement des épisodes de mes séries préférés. Une solution s'offre à vous avec ce merveilleux site : Tv Gorge - www.tvgorge.com Moteur de recherche à l'appui, vous pouvez ...
Cliquez pour lire la suite de l'article par orion TECHDAYS PARIS 2010 : LA BI DANS SHAREPOINT 2010TECHDAYS PARIS 2010 : LA BI DANS SHAREPOINT 2010 par ROMELARD Fabrice
Animé par: Vincent Bellet et Baptiste Giraudier La BI dans SharePoint 2010, Les nouveaux services d'application dans SP2010 et SQL Server Reporting services 2008 R2. La BI dans SharePoint est généralisée pour tous afin de permettre à tous les coll...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice
Logiciels
DB-MAIN (9.1.0)DB-MAIN (9.1.0)DB-MAIN is a data-modeling and data-architecture tool. It is designed to help developers and anal... Cliquez pour télécharger DB-MAIN Xilisoft DPG Convertisseur (5.1.37.0120)XILISOFT DPG CONVERTISSEUR (5.1.37.0120)Xilisoft DPG Convertisseur offre aux fans de Nintendo DS une bonne solution leur permettant de dé... Cliquez pour télécharger Xilisoft DPG Convertisseur GraphicsGale (2.01.01)GRAPHICSGALE (2.01.01)GraphicsGale est un logiciel de PixelArt avec de nombreuse fonctionnalités permettant de réalisé ... Cliquez pour télécharger GraphicsGale Architecte 3D (Platinum 2010)ARCHITECTE 3D (PLATINUM 2010)Architecte 3D Platinium vous permet de concevoir facilement les plans votre future maison, de l'é... Cliquez pour télécharger Architecte 3D TeamViewer 5 (TeamViewer 5)TEAMVIEWER 5 (TEAMVIEWER 5)Dépanner un ami,expliquer une manipulation devient un jeu d'enfant.
Prise en main d'un autre ord... Cliquez pour télécharger TeamViewer 5
|