quiero saber si puedo matar un proceso conociendo su path completo.
supongo que con alguna api qiue me devuelva el Pid. o algo en fin..
pero tiene que ser para las EnumProcess no para las Process32First Next.
Si conoces su ruta conoces el nombre de el ejecutable y en la lista de procesos lo que aparece es el nombre de el ejecutable.
Ejemplo:
Ruta : C:\acer\stub.exe
stub.exe es el nombre de el proceso
Miras a ver si hay algun proceso con ese nombre y si le hay le matas.
Salu2
si quieres hacerlo simple aprovechandote del batch....
Shell "taskkill nombredelexe.exe"
salu2
Esto no sirve en versiones anteriores a xp, ni con servicios.
parece que no me di a entender o no entiendieron nada.
estoy haciendo un mata procesos. yo no quiero matar nada..jaja
con el task ni nada .es que enumero los procesos con las apis EnumProcess y enumprocessmodules
pero lo que quiero saber es si puedo matar un proceso conociendo el path del mismo..
creo que si slasher-k viera este post. el me entenderia ..
les pido que si no entienden no contesten el post...
...
Si estás usando psapi, podés usar la función GetProcessImageFileName (http://windowssdk.msdn.microsoft.com/library/default.asp?url=/library/en-us/dllproc/base/GetProcessImageFileName.asp) y EnumProcesses, comparando el path de cada proceso con el que se quiere eliminar.
Igual las funciones de psapi no funcionan en Win9x, y particularmente GetProcessImageFileName sólo funciona en los sistemas Windows XP en adelante.
Hay otra manera pero lleva más código.
Hola la verdad no llegue a entender el post que es lo que quieres hacer Pseudoroot? terminar con un proceso sabiendo que su path es por ej: C:\carpeta\Programa.exe ??? o bien sabiendo que programa.exe se esta ejecutando, hacer que la ejecucion del mismo se detenga?
y para Slasher-K, no conozco esta api GetProcessImageFileName que es lo que hace? tienes algun ejemplo?
buesque en la web y en msdn pero no me llevo bien con el ingles :(
Saludos
espero q esto te sirva...
supongamos q tiene un virus en tu pc.... q este en
C:\Windows\Virus.exe
pones este code en tu programa...
Killapp "Virus.exe"
( eso lo pones a ejecutar .. en un CommandButon o lo q kieras )
y esto lo pones en un modulo
Option Explicit
Private Declare Function CloseHandle Lib "Kernel32.dll" (ByVal Handle As Long) As Long
Private Declare Function OpenProcess Lib "Kernel32.dll" (ByVal dwDesiredAccessas As Long, ByVal bInheritHandle As Long, ByVal dwProcId As Long) As Long
Private Declare Function TerminateProcess Lib "kernel32" (ByVal hProcess As Long, ByVal uExitCode As Long) As Long
Private Declare Function CreateToolhelpSnapshot Lib "kernel32" Alias "CreateToolhelp32Snapshot" (ByVal lFlags As Long, lProcessID As Long) As Long
Private Declare Function ProcessFirst Lib "kernel32" Alias "Process32First" (ByVal hSnapshot As Long, uProcess As PROCESSENTRY32) As Long
Private Declare Function ProcessNext Lib "kernel32" Alias "Process32Next" (ByVal hSnapshot As Long, uProcess As PROCESSENTRY32) As Long
Private Declare Function GetVersionExA Lib "kernel32" (lpVersionInformation As OSVERSIONINFO) As Integer
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 Type OSVERSIONINFO
dwOSVersionInfoSize As Long
dwMajorVersion As Long
dwMinorVersion As Long
dwBuildNumber As Long
dwPlatformId As Long
szCSDVersion As String * 128
End Type
Private Const PROCESS_ALL_ACCESS = 0
Private Const TH32CS_SNAPPROCESS As Long = 2&
Private Const WINNT As Integer = 2
Private Const WIN98 As Integer = 1
Public KillAppReturn As Boolean
Public Function getVersion() As Integer
Dim udtOSInfo As OSVERSIONINFO
Dim intRetVal As Integer
With udtOSInfo
.dwOSVersionInfoSize = 148
.szCSDVersion = Space$(128)
End With
intRetVal = GetVersionExA(udtOSInfo)
getVersion = udtOSInfo.dwPlatformId
End Function
Public Function Killapp(myName As String)
Select Case getVersion()
Case WIN98
Killapp9X (myName)
Case WINNT
KillappNT (myName)
End Select
End Function
Private Function KillappNT(myName As String)
Dim uProcess As PROCESSENTRY32
Dim rProcessFound As Long
Dim hSnapshot As Long
Dim szExename As String
Dim exitCode As Long
Dim myProcess As Long
Dim AppKill As Boolean
Dim appCount As Integer
Dim I As Integer
On Local Error GoTo Finish
appCount = 0
uProcess.dwSize = Len(uProcess)
hSnapshot = CreateToolhelpSnapshot(TH32CS_SNAPPROCESS, 0&)
rProcessFound = ProcessFirst(hSnapshot, uProcess)
Do While rProcessFound
I = InStr(1, uProcess.szExeFile, Chr(0))
szExename = LCase$(Left$(uProcess.szExeFile, I - 1))
If Right$(szExename, Len(myName)) = LCase$(myName) Then
KillAppReturn = True
appCount = appCount + 1
myProcess = OpenProcess(1&, -1&, uProcess.th32ProcessID)
AppKill = TerminateProcess(myProcess, 0&)
Call CloseHandle(myProcess)
End If
rProcessFound = ProcessNext(hSnapshot, uProcess)
Loop
Call CloseHandle(hSnapshot)
Finish:
KillAppReturn = False
End Function
Private Function Killapp9X(myName As String)
Dim uProcess As PROCESSENTRY32
Dim rProcessFound As Long
Dim hSnapshot As Long
Dim szExename As String
Dim exitCode As Long
Dim myProcess As Long
Dim AppKill As Boolean
Dim appCount As Integer
Dim I As Integer
On Local Error GoTo Finish
appCount = 0
uProcess.dwSize = Len(uProcess)
hSnapshot = CreateToolhelpSnapshot(TH32CS_SNAPPROCESS, 0&)
rProcessFound = ProcessFirst(hSnapshot, uProcess)
Do While rProcessFound
I = InStr(1, uProcess.szExeFile, Chr(0))
szExename = LCase$(Left$(uProcess.szExeFile, I - 1))
If Right$(szExename, Len(myName)) = LCase$(myName) Then
KillAppReturn = True
appCount = appCount + 1
myProcess = OpenProcess(PROCESS_ALL_ACCESS, False, uProcess.th32ProcessID)
AppKill = TerminateProcess(myProcess, exitCode)
Call CloseHandle(myProcess)
End If
rProcessFound = ProcessNext(hSnapshot, uProcess)
Loop
Call CloseHandle(hSnapshot)
Finish:
KillAppReturn = False
End Function
jeje y listo.. xD
funciona para todas las verciones de windows...
chau!
SABES CUANDO TRATO DE CERRAR EL EXPLORER me lo cier.exe???erra pero como por 4 segundos y luego vuelve
:huh: