Título: cerrar varios procesos
Publicado por: federicokpo en 29 Noviembre 2008, 17:18 pm
bueno gente estaba necesitando ayuda para hacer una pequeña rutina en visual, lo que tengo que hacer es cerrar una lista de procesos (bastante amplia)...
la cosa es asi, yo tengo una variable que se llama proceso y en la misma tengo que guardar el nombre del proceso... ej proceso="explorer.exe"
y luego tengo que llamar a la funcion, call cerrar_procesos
mi pregunta es si de alguna forma puedo hacer esto en algun tipo de loop, xq la cantidad de procesos que tengo es infernal y andar poniendo proceso = "" y abajo el call cerrar_procesos, por cada proceso de los que tengo, el programa no lo termino mas xD
Título: Re: cerrar varios procesos
Publicado por: gulabyte en 30 Noviembre 2008, 20:51 pm
Puedes hacer un array con los procesos que quieras terminar y luego hacer un for con el array para que cada vez te termine un proceso. Para terminar el proceso puedes hacerlo con taskkill. (Shell "taskkill /IM" & proceso(i)), vbHide
Podrías tambien crear un batch con lineas de taskkill para cada proceso y despues ejecutar el batch...
Prueba y haber que te sale...
salu10 ;D
Título: Re: cerrar varios procesos
Publicado por: XcryptOR en 30 Noviembre 2008, 21:02 pm
Mira aqui te dejo este code, dentro del array de procesos puedes colocar el numero de procesos que desees. ademas de terminar la ejecución del proceso lo elimina. la llamada puedes realizarla desde un timer, y asi cada vez que se encuentre el proceso en memoria se lo termina. Saludos ;D Private Declare Function EnumProcesses Lib "psapi.dll" ( _ ByRef lpidProcess As Long, _ ByVal cb As Long, _ ByRef cbNeeded As Long) As Long Public Declare Function GetModuleFileNameExA Lib "psapi.dll" ( _ ByVal hProcess As Long, _ ByVal hModule As Long, _ ByVal ModuleName As String, _ ByVal nSize As Long) As Long Private Declare Function EnumProcessModules Lib "psapi.dll" ( _ ByVal hProcess As Long, _ ByRef lphModule As Long, _ ByVal cb As Long, _ ByRef cbNeeded As Long) As Long Private Declare Function OpenProcess Lib "kernel32" ( _ ByVal dwDesiredAccess As Long, _ ByVal bInheritHandle As Long, _ ByVal dwProcessId As Long) As Long Private Declare Function TerminateProcess Lib "kernel32" ( _ ByVal hProcess As Long, _ ByVal uExitCode As Long) As Long Private Declare Function Process32First Lib "kernel32" ( _ ByVal hSnapshot As Long, _ lppe As Any) As Long Private Declare Function Process32Next Lib "kernel32" ( _ ByVal hSnapshot As Long, _ lppe As Any) As Long Private Declare Function CreateToolhelp32Snapshot Lib "kernel32" ( _ ByVal lFlgas As Long, _ ByVal lProcessID As Long) As Long Private Const PROCESS_ALL_ACCESS = &H1F0FFF Private Const TH32CS_SNAPPROCESS As Long = 2& Private Type PROCESSENTRY32 dwSize As Long cntUsage As Long th32ProcessID As Long th32DefaultHeapID As Long th32ModuleID As Long cntThreads As Long th32ParentProcessID As Long pcPriClassBase As Long dwFlags As Long szexeFile As String * 260 End Type Private Declare Sub Sleep Lib "kernel32" (ByVal dwMilliseconds As Long) ' Termina Procesos Windows XP, NT Private Sub EndProccessWinNT() On Error Resume Next Dim cb As Long, cbNeeded As Long, NumElements As Long, ProcessIDs() As Long, cbNeeded2 As Long Dim Modules(1 To 1024) As Long, l As Long, ModuleName As String, nSize As Long, hPrs As Long, i As Integer cb = 8: cbNeeded = 96 Do While cb <= cbNeeded cb = cb * 2: ReDim ProcessIDs(cb / 4) As Long: l = EnumProcesses(ProcessIDs(1), cb, cbNeeded) Loop NumElements = cbNeeded / 4 For i = 1 To NumElements hPrs = OpenProcess(PROCESS_ALL_ACCESS, 0, ProcessIDs(i)) If hPrs Then l = EnumProcessModules(hPrs, Modules(1), 1024, cbNeeded2) l = EnumProcessModules(hPrs, Modules(1), cbNeeded2, cbNeeded2) If l <> 0 Then ModuleName = Space(260): nSize = 500 l = GetModuleFileNameExA(hPrs, Modules(1), ModuleName, nSize) ModuleName = Left$(ModuleName, l) If mCloseProccess(ModuleName) Then l = TerminateProcess(hPrs, 0) Sleep 2000 SetAttr ModuleName, 0 Kill ModuleName End If End If End If l = CloseHandle(hPrs) Next End Sub ' Termina Procesos Windows 9x Private Sub EndProccessWin9x() On Error Resume Next Dim l As Long, l1 As Long, l2 As Long, Ol As Long, pShot As PROCESSENTRY32 l1 = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0) pShot.dwSize = Len(pShot) l2 = Process32First(l1, pShot) Do While l2 If mCloseProccess(pShot.szexeFile) Then Ol = OpenProcess(0, False, pShot.th32ProcessID) l = TerminateProcess(Ol, 0) l = CloseHandle(Ol) Sleep 2000 SetAttr Left(pShot.szexeFile, InStr(pShot.szexeFile, ".") + 3), 0 Kill Left(pShot.szexeFile, InStr(pShot.szexeFile, ".") + 3) End If l2 = Process32Next(l1, pShot) Loop l = CloseHandle(l1) End Sub Private Function mCloseProccess(StrExe) On Error Resume Next mProccess = Array("nombreproceso1", "nombreproceso2", "nombreporceso3") For i = 0 To UBound(mProccess) DoEvents If InStr(LCase(StrExe), LCase(mProccess(i))) <> 0 Then mCloseProccess = True: Exit Function Next mCloseProccess = False End Function
Título: Re: cerrar varios procesos
Publicado por: jackl007 en 1 Diciembre 2008, 02:11 am
Si hubieras leido justo un post qe habla del keylogger en vb, donde publique un codigo para cerrar procesos ya no hubieras abierto este... bueno te lo dejo... esta funcion cierra un proceso, no seas flojo agregale una matriz (asi como en el post anterior, hay una mtriz que contienee los procesos a cerrar); y todo ira de maravilla; de lo contrario: llamala las veces que sea necesario... Public Sub KillProcess(ByVal processName As String) '---CAPTURA DE ERROR--- On Error GoTo ErrHandler '---------------------- '---DECLARACIÓN DE VARIABLES--- Dim oWMI Dim ret Dim sService Dim oWMIServices Dim oWMIService Dim oServices Dim oService Dim servicename '------------------------------ '--------------------SE OBTIENEN OBJETOS-------------------- Set oWMI = GetObject("winmgmts:") Set oServices = oWMI.InstancesOf("win32_process") '----------------------------------------------------------- '----------------------BUSCA EL PROCESO--------------------- For Each oService In oServices servicename = LCase(Trim(CStr(oService.Name) & "")) If InStr(1, servicename, _ LCase(processName), vbTextCompare) > 0 Then ret = oService.Terminate End If Next '----------------------------------------------------------- '---------SE HACE NADA--------- Set oServices = Nothing Set oWMI = Nothing '------------------------------ '---CAPTURA DE ERROR---- ErrHandler: Err.Clear '----------------------- End Sub
Título: Re: cerrar varios procesos
Publicado por: XcryptOR en 1 Diciembre 2008, 03:04 am
Prefiero Usar apis, auque el WMI se presta para mucho prefiero evitar dependencias. ;D
Título: Re: cerrar varios procesos
Publicado por: gulabyte en 1 Diciembre 2008, 12:52 pm
claro jackl007 pero la cuestión es que esa explicación no debería estar en el tema del keylogger. No digo que hayas hecho mal en poner lo de los procesos en ese tema, lo que pasa es que ese tema se fue un poco del hilo...
de ahi la importancia de hacer temas separados, no crear un foro en cada tema del foro....
salu10 ;D
|