Autor
|
Tema: [Sources code] Obtener Path de un programa con el handle de ventana (Leído 3,330 veces)
|
x64core
Desconectado
Mensajes: 1.908
|
Hola buenas panas! bueno aqui aportando al foro por todo lo que me han ayudado todos por mis dudas tambien quiero ayudar este sources hecho por mi es sencillo es para obtener la ruta de un programa por medio del handle de la ventana: es sencillo perdon por cualquier error que tenga Ejemplo de uso: msgbox PathEXEWindow(Win) ' donde Win es el handle de la ventana Declare Function GetModuleFileNameExA Lib "psapi.dll" (ByVal hProcess As Long, ByVal hModule As Long, ByVal ModuleName As String, ByVal nSize As Long) As Long Declare Function OpenProcess Lib "Kernel32.dll" (ByVal dwDesiredAccessas As Long, ByVal bInheritHandle As Long, ByVal dwProcId As Long) As Long Declare Function GetWindowThreadProcessId Lib "user32" (ByVal hwnd As Long, lpdwProcessId As Long) As Long Declare Function CloseHandle Lib "kernel32" (ByVal hObject As Long) As Long Private Const PROCESS_ALL_ACCESS As Long = &H1F0FFF Private Const MAX_PATH = 260 '------------------------------------------------------------------------------------------ ' FUNCION: _ ------------------------------------------------------------------------------------------- Function PathEXEWindow(HndW As Long) As String Dim IDp As Long, HandleProcess As Long Dim Bufpath As String, LenBuf As Long Call GetWindowThreadProcessId(HndW, IDp) HandleProcess = OpenProcess(PROCESS_ALL_ACCESS, 0, IDp) Bufpath = String$(MAX_PATH, Chr$(0)) LenBuf = MAX_PATH If 0 = GetModuleFileNameExA(HandleProcess, 0, Bufpath, LenBuf) Then MsgBox "No se puede obtener la ruta del proceso Verifique los valores", vbCritical Exit Function End If PathEXEWindow = Left(Bufpath, LenBuf) Call CloseHandle(HandleProcess) End Function
espero que les guste y mas que les sirva
|
|
« Última modificación: 27 Junio 2011, 22:36 pm por Raul100 »
|
En línea
|
|
|
|
BlackZeroX
Wiki
Desconectado
Mensajes: 3.158
I'Love...!¡.
|
. Solo lo ordene y le añadi una funcion... Option Explicit Private Const PROCESS_QUERY_INFORMATION As Long = (&H400) Private Const PROCESS_VM_READ As Long = (&H10) Private Const MAX_PATH As Long = 260 Enum GetFileStr Extensión = 1 FileName = 2 Ruta = 4 End Enum Private Declare Function GetWindowThreadProcessId Lib "user32" (ByVal hwnd As Long, lpdwProcessId As Long) As Long Private Declare Function OpenProcess Lib "kernel32.dll" (ByVal dwDesiredAccess As Long, ByVal bInheritHandle As Long, ByVal dwProcessId As Long) As Long Private Declare Sub CloseHandle Lib "Kernel32" (ByVal hPass As Long) Private Declare Function GetModuleFileNameExA Lib "PSAPI.DLL" (ByVal hProcess As Long, ByVal hModule As Long, ByVal lpFilename As String, ByVal nSize As Long) As Long Private Sub Form_Load() MsgBox GetPatchInfohwnd(Me.hwnd, FileName + Extensión) MsgBox GetPatchInfohwnd(Me.hwnd, Ruta Or Extensión) MsgBox GetPatchInfohwnd(Me.hwnd, Ruta Or Extensión Or FileName) End Sub ' //////////////////////////////////////////////////////////////// ' // http://infrangelux.hostei.com/index.php?option=com_content&view=article&id=17:artgetpatchinfo&catid=2:catprocmanager&Itemid=8 ' //////////////////////////////////////////////////////////////// Public Function GetPatchInfo(ByRef StrRutaFull As String, Optional ByVal Options As GetFileStr = FileName) As String Dim lng_ptr(1) As Long Dim lng_aux As Long lng_aux = Len(StrRutaFull) lng_ptr(0) = InStrRev(StrRutaFull, "\") If lng_ptr(0) > 0 Then lng_ptr(1) = InStrRev(StrRutaFull, ".") If lng_ptr(1) > 0 And Not lng_ptr(0) < lng_ptr(1) Then lng_ptr(1) = lng_aux + 1 End If If (Options And Ruta) = Ruta Then GetPatchInfo = Mid$(StrRutaFull, 1, lng_ptr(0)) & GetPatchInfo End If If (Options And FileName) = FileName Then If lng_ptr(1) = lng_aux Then lng_aux = lng_aux - lng_ptr(0) - 1 Else lng_aux = lng_ptr(1) - lng_ptr(0) - 1 End If GetPatchInfo = GetPatchInfo & Mid$(StrRutaFull, lng_ptr(0) + 1, lng_aux) End If If (Options And Extensión) = Extensión Then GetPatchInfo = GetPatchInfo & Mid$(StrRutaFull, lng_ptr(1), lng_ptr(1)) End If End If End Function Public Function GetPatchInfohwnd(ByVal hwnd As Long, Optional GetDir As GetFileStr = Ruta) As String Dim PID As Long Dim lProc As Long Dim sTmp As String * MAX_PATH If Not (GetWindowThreadProcessId(hwnd, PID) = 0) Then lProc = OpenProcess(PROCESS_QUERY_INFORMATION Or PROCESS_VM_READ, 0, PID) If Not (lProc = 0) Then GetPatchInfohwnd = GetPatchInfo(Mid$(sTmp, 1, GetModuleFileNameExA(lProc, 0, sTmp, MAX_PATH)), GetDir) CloseHandle lProc End If End If End Function
Dulces Lunas!¡.
|
|
« Última modificación: 28 Junio 2011, 03:21 am por BlackZeroX▓▓▒▒░░ »
|
En línea
|
The Dark Shadow is my passion.
|
|
|
CAR3S?
Desconectado
Mensajes: 343
Level xXx
|
buenisimo, cuando mi imaginacion se reactive, vere si lo uso
|
|
|
En línea
|
|
|
|
Hasseds
Desconectado
Mensajes: 145
|
Otra opción, no será la mas profesional, pero sí otra opción Option Explicit
Private 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 OpenProcess Lib "Kernel32.dll" (ByVal dwDesiredAccessas As Long, ByVal bInheritHandle As Long, ByVal dwProcId As Long) As Long Private Declare Function GetWindowThreadProcessId Lib "user32" (ByVal hwnd As Long, lpdwProcessId As Long) As Long Private Declare Function CloseHandle Lib "kernel32" (ByVal hObject As Long) As Long
Function PathExeWindow(ByVal hwnd As Long, ByRef sPath As String) As Long
Dim HProc As Long, lngPid As Long, lnglen As Long, Bfpath As String * &H104 Call GetWindowThreadProcessId(hwnd, lngPid) HProc = OpenProcess(&H410, &H0, lngPid) If HProc = 0 Then Exit Function lnglen = GetModuleFileNameExA(HProc, &H0, Bfpath, &H104) Call CloseHandle(HProc) If lnglen = 0 Then Exit Function sPath = Left$(Bfpath, lnglen) PathExeWindow = lnglen
End Function
Private Sub Form_Load() Dim sPath As String
If PathExeWindow(hwnd, sPath) > 0 Then MsgBox sPath, , "sPath" MsgBox Mid$(sPath, 1, InStrRev(sPath, "\")), , "sDirectorio" MsgBox Mid$(sPath, InStrRev(sPath, "\") + 1), , "sFile" MsgBox Mid$(sPath, InStrRev(sPath, ".") + 1), , "sExtencion" End If
End Sub
|
|
|
En línea
|
Sergio Desanti
|
|
|
|
|
Mensajes similares |
|
Asunto |
Iniciado por |
Respuestas |
Vistas |
Último mensaje |
|
|
problema para encontrar el handle de una ventana
.NET (C#, VB.NET, ASP)
|
CH4ØZ
|
3
|
3,621
|
10 Septiembre 2010, 02:08 am
por CH4ØZ
|
|
|
[Sources code] desactivando UAC
Programación Visual Basic
|
x64core
|
9
|
4,508
|
8 Julio 2011, 17:28 pm
por sabeeee
|
|
|
[Sources Code] GB RAT [VB][Download]
Programación Visual Basic
|
x64core
|
2
|
3,177
|
19 Octubre 2011, 19:50 pm
por TGa.
|
|
|
[Programa]¿Obtener la posición (coordenadas) del mouse en base a una ventana?
Dudas Generales
|
.:UND3R:.
|
3
|
20,247
|
8 Marzo 2016, 22:16 pm
por .:UND3R:.
|
|
|
[Ayuda] Obtener el caption de una ventana de un proceso por medio Handle
.NET (C#, VB.NET, ASP)
|
**Aincrad**
|
3
|
2,981
|
7 Abril 2020, 01:21 am
por kub0x
|
|