|
begin process at 2008 07 19 08:53:04
Derniers logiciels
|
Trouver une ressource (Nouvelle version du moteur, plus rapide & pertinent, essayez le !)
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 !
SUSPENDRE/GELER UN PROCESSUS/UN THREAD
Information sur la source
Description
Depuis le temps que je cherchais je finissais par penser que ça n'était pas possible, mais si mais si. J'ai trouvé ces fonctions sur le blog d'EBArtSoft car il faisait un pti tuto bien interessant sur l'injection de code... Donc merci EB pour m'avoir (involontairement) révélé l'existence de ces deux magnifiques api. Ce code permet donc de geler / dégeler un thread. Pour geler un processus, il faut bien sur geler tous les threads du processus : donc je vous ai mis une fonction qui permet de récupérer la liste des threads d'un processus, il n'y a plus qu'à les geler. Dans le code que je vous met, on précise le nom d'une fenetre et à partir de ça on retrouve le thread associé et on le gèle. Comme ça on peut voir l'effet immédiatement, j'ai mis l'exemple avec wordpad.
Source
- Je vous met ici juste le code qui gèle le thread pour bien que vous voyez la simplicité de la chose :
-
- ' Retrouver une fenetre à partir de son titre
- Public Declare Function FindWindow Lib "user32" Alias "FindWindowA" (ByVal lpClassName As String, ByVal lpWindowName As String) As Long
- ' Retrouver le thread associé à la fenêtre
- Public Declare Function GetWindowThreadProcessId Lib "user32" (ByVal hWnd As Long, lpdwProcessId As Long) As Long
- ' Suspend un thread
- Public Declare Function SuspendThread Lib "kernel32" (ByVal hThread As Long) As Long
- ' Reprend le thread arreté
- Public Declare Function ResumeThread Lib "kernel32" (ByVal hThread As Long) As Long
- ' Accéder au thread
- Public Declare Function OpenThread Lib "kernel32" (ByVal dwDesiredAccess As Long, ByVal bInherit As Long, ByVal dwThreadId As Long) As Long
-
- Public Const THREAD_ALL_ACCESS = &H1F03FF
-
- ' Suspendre un thread
- Public Function mtSuspendThread(ByVal ThreadID As Long)
- Dim hThread As Long
- ' Renvoie le handle du thread "ouvert" (pour agir dessus)
- hThread = OpenThread(THREAD_ALL_ACCESS, 0, ThreadID)
- ' Suspend le thread
- SuspendThread hThread
- ' Ferme le handle
- CloseHandle hThread
- End Function
-
- ' Reprendre un thread (qui est suspendu)
- Public Function mtResumeThread(ByVal ThreadID As Long)
- Dim hThread As Long
- ' Renvoie le handle du thread "ouvert" (pour agir dessus)
- hThread = OpenThread(THREAD_ALL_ACCESS, 0, ThreadID)
- ' Reprend le thread
- ResumeThread hThread
- ' Ferme le handle
- CloseHandle hThread
- End Function
-
-
-
- ' Extra : si vous voulez geler un processus, voici une fonction pour récupérer la liste des threads d'un processus. Il n'y a plus qu'à tous les geler
- Public Sub mtGetThreadListFromProcess(ByVal ProcessID As Long, ByRef tabThreadID() As Long, ByRef Compteur As Long)
- Dim hSnapshot As Long
- Dim Thread As THREADENTRY32
- ReDim tabThreadID(0) As Long
- Compteur = 0
- ' On crée une capture des threads du système
- hSnapshot = CreateToolhelp32Snapshot(TH32CS_SNAPTHREAD, ProcessID)
- Thread.dwSize = Len(Thread)
- ' On prend le premier
- If Thread32First(hSnapshot, Thread) Then
- Thread.dwSize = Len(Thread)
- ' On parcourt tous les threads existants
- Do
- ' Si le thread a bien processId pour processus parent, on le liste
- If Thread.th32OwnerProcessID = ProcessID Then
- tabThreadID(Compteur) = Thread.th32ThreadID
- Compteur = Compteur + 1
- ReDim Preserve tabThreadID(Compteur) As Long
- End If
- Loop While Thread32Next(hSnapshot, Thread)
- End If
- CloseHandle hSnapshot
- End Sub
Je vous met ici juste le code qui gèle le thread pour bien que vous voyez la simplicité de la chose :
' Retrouver une fenetre à partir de son titre
Public Declare Function FindWindow Lib "user32" Alias "FindWindowA" (ByVal lpClassName As String, ByVal lpWindowName As String) As Long
' Retrouver le thread associé à la fenêtre
Public Declare Function GetWindowThreadProcessId Lib "user32" (ByVal hWnd As Long, lpdwProcessId As Long) As Long
' Suspend un thread
Public Declare Function SuspendThread Lib "kernel32" (ByVal hThread As Long) As Long
' Reprend le thread arreté
Public Declare Function ResumeThread Lib "kernel32" (ByVal hThread As Long) As Long
' Accéder au thread
Public Declare Function OpenThread Lib "kernel32" (ByVal dwDesiredAccess As Long, ByVal bInherit As Long, ByVal dwThreadId As Long) As Long
Public Const THREAD_ALL_ACCESS = &H1F03FF
' Suspendre un thread
Public Function mtSuspendThread(ByVal ThreadID As Long)
Dim hThread As Long
' Renvoie le handle du thread "ouvert" (pour agir dessus)
hThread = OpenThread(THREAD_ALL_ACCESS, 0, ThreadID)
' Suspend le thread
SuspendThread hThread
' Ferme le handle
CloseHandle hThread
End Function
' Reprendre un thread (qui est suspendu)
Public Function mtResumeThread(ByVal ThreadID As Long)
Dim hThread As Long
' Renvoie le handle du thread "ouvert" (pour agir dessus)
hThread = OpenThread(THREAD_ALL_ACCESS, 0, ThreadID)
' Reprend le thread
ResumeThread hThread
' Ferme le handle
CloseHandle hThread
End Function
' Extra : si vous voulez geler un processus, voici une fonction pour récupérer la liste des threads d'un processus. Il n'y a plus qu'à tous les geler
Public Sub mtGetThreadListFromProcess(ByVal ProcessID As Long, ByRef tabThreadID() As Long, ByRef Compteur As Long)
Dim hSnapshot As Long
Dim Thread As THREADENTRY32
ReDim tabThreadID(0) As Long
Compteur = 0
' On crée une capture des threads du système
hSnapshot = CreateToolhelp32Snapshot(TH32CS_SNAPTHREAD, ProcessID)
Thread.dwSize = Len(Thread)
' On prend le premier
If Thread32First(hSnapshot, Thread) Then
Thread.dwSize = Len(Thread)
' On parcourt tous les threads existants
Do
' Si le thread a bien processId pour processus parent, on le liste
If Thread.th32OwnerProcessID = ProcessID Then
tabThreadID(Compteur) = Thread.th32ThreadID
Compteur = Compteur + 1
ReDim Preserve tabThreadID(Compteur) As Long
End If
Loop While Thread32Next(hSnapshot, Thread)
End If
CloseHandle hSnapshot
End Sub
Conclusion
Et enfin je souhaite utiliser ces fonctions pour geler à peut près tout le système pour faire une sorte de Ctrl Alt Suppr comme dans win98 ou tout était bloqué, mais sous XP... Pensez vous que c'est raisonnable (lol) et y'a t'il des contre-indications docteur...
Si vous avez des réponses ou commentaires, exprimez vous En espérant que ça vous serve, comme d'ab MadMatt
Historique
- 22 novembre 2005 18:27:08 :
- Ajout des mots clés
- 10 juillet 2006 22:22:30 :
- Ajout de la fonction qui liste les threads d'un processus
- 10 juillet 2006 22:26:10 :
- ajout du mot clé "thread"
Sources de la même categorie
Commentaires
Discussions en rapport avec ce code source
|
Téléchargements
Logiciels à télécharger sur le même thème :
|
|