Foro de elhacker.net

Programación => Programación Visual Basic => Mensaje iniciado por: x64core en 27 Agosto 2011, 06:34 am



Título: obtener el hwnd de un programa sin form
Publicado por: x64core en 27 Agosto 2011, 06:34 am
buenas pues esa duda tengo :P como puedo obtener el hwnd de un programa de VB sin form? estoy codeando un programa sin form ( modulo como main el principal ) y entonces llege a esa parte que necesito el hwnd :P normalmente se hace me.hwnd ( me = form ) pero ahora veo que el modulo no tiene hwnd al menos tiene esa propiedad :P como puedo hacer? gracias :)


Título: Re: obtener el hwnd de un programa sin form
Publicado por: BlackZeroX en 27 Agosto 2011, 07:04 am
.
Ponle entonces &H0 o 0, el hwnd es propio de ventanas y solo es asosiativos normalmente...

Dulces Lunas!¡.


Título: Re: obtener el hwnd de un programa sin form
Publicado por: x64core en 27 Agosto 2011, 07:17 am
gracias BlackZeroX :) eso funciona con hooks? la verdad por el momento lo quiero para la api Settimer para el primer parametro que me pide :P y luego creo que lo usare para aplicarlo a hooks...

PD: una duda  :huh: para eliminarlo con killtimer? :P
ya que si aplico 0 en killtimer entonces escribo 0 ???  :huh:


Título: Re: obtener el hwnd de un programa sin form
Publicado por: BlackZeroX en 27 Agosto 2011, 07:30 am
.
La MSDN No muerde y si no sabes ingles hay tienes el traductor de google.

http://msdn.microsoft.com/en-us/library/ms644906%28v=vs.85%29.aspx

http://msdn.microsoft.com/en-us/library/ms644903%28v=vs.85%29.aspx

Dulces Lunas!¡.


Título: Re: obtener el hwnd de un programa sin form
Publicado por: x64core en 27 Agosto 2011, 07:48 am
 :xD si lo lei tio por eso me entro la curiosidad ya que al escribirle 0 comprendi que el argumento idevent se ignora :P y por eso tenia duda de como si no lo ignorara el parametro lo usara para darle un numero para identificarlo :P pero lo ignora :P y comprobe y la funcion killtimer me devuelve 0 eso quiere decir que la funcion falla :P y no libera el timer :P


Título: Re: obtener el hwnd de un programa sin form
Publicado por: x64core en 27 Agosto 2011, 08:10 am
hice este ejemplo y comprobe que no funciona :P noce en que fallo :P

modulo bas
Código
  1. Option Explicit
  2. Declare Function SetTimer Lib "user32" (ByVal hwnd As Long, ByVal nIDEvent As Long, ByVal uElapse As Long, ByVal lpTimerFunc As Long) As Long
  3. Declare Function KillTimer Lib "user32" (ByVal hwnd As Long, ByVal nIDEvent As Long) As Long
  4.  
  5. Dim A As Long
  6. Dim B As Boolean
  7.  
  8. Sub main()
  9. A = SetTimer(0, 0, 30000, AddressOf TimerProc)
  10. Debug.Print A
  11. Do While Not B
  12. DoEvents
  13. Loop
  14. End Sub
  15.  
  16. Sub TimerProc(ByVal hwnd As Long, ByVal nIDEvent As Long, ByVal uElapse As Long, ByVal lpTimerFunc As Long)
  17. Debug.Print "+1"
  18. Debug.Print A
  19. Debug.Print KillTimer(A, 0)
  20. B = True
  21. End Sub


el resultado del debug.print:


Código:
26430 
+1
26430
0       <--------- no lo libera :P (valor devuelto de la llamada a funcion killtimer )

luego lo termine de comprobar porq cuando termina sub main y vuelvo a vb en diseño el timer aun sigue marcando y en el debug.print me escribe

Código:
+1
0
0


Título: Re: obtener el hwnd de un programa sin form
Publicado por: x64core en 27 Agosto 2011, 08:26 am
 :xD :xD :xD
lo resolvi
bueno mi error era a la hora de liberarlo :xD
el identificador q me devuelve settimer es el idevent no el hwnd del timer :)

Código:
Debug.Print KillTimer(0, A)

debug.print:

Código:
 26196 
+1
 26196
 1


Título: Re: obtener el hwnd de un programa sin form
Publicado por: BlackZeroX en 27 Agosto 2011, 22:17 pm
.
Código
  1.  
  2. Option Explicit
  3.  
  4. Declare Function SetTimer Lib "user32" (ByVal hwnd As Long, ByVal nIDEvent As Long, ByVal uElapse As Long, ByVal lpTimerFunc As Long) As Long
  5. Declare Function KillTimer Lib "user32" (ByVal hwnd As Long, ByVal nIDEvent As Long) As Long
  6. Declare Function WaitMessage Lib "user32" () As Long
  7.  
  8. Dim iTmr            As Long
  9.  
  10. Sub main()
  11.    iTmr = SetTimer(0, 0, 300, AddressOf TimerProc)
  12.    Do While Not (iTmr = 0)
  13.        DoEvents
  14.        WaitMessage
  15.    Loop
  16. End Sub
  17.  
  18. Sub TimerProc(ByVal hwnd As Long, ByVal nIDEvent As Long, ByVal uElapse As Long, ByVal lpTimerFunc As Long)
  19.    Debug.Print KillTimer(hwnd, iTmr)
  20.    iTmr = 0
  21. End Sub
  22.  
  23.  

Dulces Lunas!¡.


Título: Re: obtener el hwnd de un programa sin form
Publicado por: Hasseds en 27 Agosto 2011, 23:16 pm

buenas pues esa duda tengo :P como puedo obtener el hwnd de un programa de VB sin form?


El tema ya quedó resuelto, pero si alguna vez tenés que obtener el hwnd de un Main podes usar FindWindow. (Acabo de enterarme de esto, ya que también pensaba que este tipo de hwnd era unicamente propio de ventanas).

Código:



Option Explicit

Private Declare Function FindWindow Lib "user32" Alias "FindWindowA" (ByVal lpClassName As String, ByVal lpWindowName As String) As Long
 
Sub Main()
  
  Dim lpClase As String
  
  If Not App.LogMode = 0 Then
    lpClase = "ThunderRT6Main" ' Exe Compilado
  Else
    lpClase = "ThunderMain" ' en el IDE
  End If
  
  MsgBox FindWindow(lpClase, App.Title)

End Sub

 








Título: Re: obtener el hwnd de un programa sin form
Publicado por: BlackZeroX en 28 Agosto 2011, 00:26 am
El tema ya quedó resuelto, pero si alguna vez tenés que obtener el hwnd de un Main podes usar FindWindow. (Acabo de enterarme de esto, ya que también pensaba que este tipo de hwnd era unicamente propio de ventanas).

En efecto solo son de ventanas, los procesos no tienen hwnd.
Por ello El PROCESO MAIN() al igual que los demas, NO tienen hwnd.

Cita de: MSDN Microsoft http://support.microsoft.com/kb/259673/es

Todas las aplicaciones de Visual Basic tienen una ventana de nivel superior invisible que procesa los eventos y mensajes. En el modo de diseño, la ventana es ThunderMain, en el modo de ejecución, la ventana es ThunderRT6Main. El RT6 refleja el versión de Visual Basic que se utiliza. Las dos ventanas tienen el nombre del proyecto o el nombre del archivo ejecutable como el título de ventana. Esto es donde se establece el icono de aplicación.


Dulces Lunas!¡.


Título: Re: obtener el hwnd de un programa sin form
Publicado por: Hasseds en 28 Agosto 2011, 00:38 am
Ok, gracias por la aclaración BlackZeroX▓▓▒▒░░ , como dije anteriormente Acabo de enterarme de este tipo hwnd,  ( voy a investigar que utilidad puede tener)

PD:  es mas practico guardar el retorno de SetTimer para  luego utilizarlo con KillTimer pero este Por Ej con este hwnd tambien se puede , lo dicho ( voy a investigar que utilidad puede tener)

Saludos









Título: Re: obtener el hwnd de un programa sin form
Publicado por: BlackZeroX en 28 Agosto 2011, 01:47 am
PD:  es mas practico guardar el retorno de SetTimer para  luego utilizarlo con KillTimer pero este Por Ej con este hwnd tambien se puede , lo dicho ( voy a investigar que utilidad puede tener)

Es una ventana oculta que resive TODOS los mensajes del sistema operativo... para evitarnos hacer el trato de los mensajes mismos tal y como lo hariamos en C/C++...

P.D.: El hwnd en el SetTimer() y KilTtimer() son solo para relacionar el mensaje WM_TIMER con un CallBack al WinProc() de la ventana X con respecto a su hwnd... de todos modos en todos los codigos ya espuestos aqui se a guardado el uIDEvent generado por SetTimer() para posteriormente usarlo en el KillTimer()...

Cita de: MSDN_Microsoft http://msdn.microsoft.com/en-us/library/ms644906(v=vs.85).aspx

Remarks

An application can process WM_TIMER messages by including a WM_TIMER case statement in the window procedure or by specifying a TimerProc callback function when creating the timer. When you specify a TimerProc callback function, the default window procedure calls the callback function when it processes WM_TIMER. Therefore, you need to dispatch messages in the calling thread, even when you use TimerProc instead of processing WM_TIMER.

The wParam parameter of the WM_TIMER message contains the value of the nIDEvent parameter.

The timer identifier, nIDEvent, is specific to the associated window. Another window can have its own timer which has the same identifier as a timer owned by another window. The timers are distinct.

SetTimer can reuse timer IDs in the case where hWnd is NULL.


Dulces Lunas!¡.


Título: Re: obtener el hwnd de un programa sin form
Publicado por: Hasseds en 28 Agosto 2011, 04:59 am

de todos modos en todos los codigos ya espuestos aqui se a guardado el uIDEvent generado por SetTimer() para posteriormente usarlo en el KillTimer()...



A eso me refería, que es mas practico como se expuso que utilizando el  Hwnd, estamos diciendo lo mismo.


es mas practico guardar el retorno de SetTimer para  luego utilizarlo con KillTimer pero esto Por Ejemplo con este hwnd tambien se puede


Código:

Valor de Retorno
Si la función tiene éxito y el parámetro hWnd es NULO, el valor de vuelta es un número entero que identifica el nuevo temporizador.se puede pasar este valor a la función de KillTimer para destruir el temporizador.




Lo que no llego a entender por qué el uIDEvent tambien se puede recuperar a travez de uElapse de TimerProc


Código:


Option Explicit

Declare Function SetTimer Lib "user32" (ByVal hwnd As Long, ByVal nIDEvent As Long, ByVal uElapse As Long, ByVal lpTimerFunc As Long) As Long
Declare Function KillTimer Lib "user32" (ByVal hwnd As Long, ByVal nIDEvent As Long) As Long
 
Dim A As Boolean
 
Sub Main()
  
  Call SetTimer(0, 0, 2000, AddressOf TimerProc)
  
 Do While Not A
    DoEvents
  Loop

End Sub
 
Sub TimerProc(ByVal hwnd As Long, ByVal nIDEvent As Long, ByVal uElapse As Long, ByVal lpTimerFunc As Long)
  Debug.Print uElapse
  Debug.Print KillTimer(0, uElapse)
  A = True
End Sub












Título: Re: obtener el hwnd de un programa sin form
Publicado por: BlackZeroX en 28 Agosto 2011, 06:58 am

Lo que no llego a entender por qué el uIDEvent tambien se puede recuperar a travez de uElapse de TimerProc


Lo que pasa es que no tiene correctamente los aprametros del callback, yo tampoco me habia dado cuenta... aqui te dejo el callback con los nombres corectamente... total solo son nombres de parametros...


http://msdn.microsoft.com/en-us/library/ms644907%28v=VS.85%29.aspx

Código
  1.  
  2. Option Explicit
  3.  
  4. Declare Function SetTimer Lib "user32" (ByVal hwnd As Long, ByVal nIDEvent As Long, ByVal uElapse As Long, ByVal lpTimerFunc As Long) As Long
  5. Declare Function KillTimer Lib "user32" (ByVal hwnd As Long, ByVal nIDEvent As Long) As Long
  6. Declare Function WaitMessage Lib "user32" () As Long
  7.  
  8. Public iTmr     As Long
  9.  
  10. Sub main()
  11.    iTmr = SetTimer(0, 0, 300, AddressOf TimerProc)
  12.    Do While Not (iTmr = 0)
  13.        DoEvents
  14.        WaitMessage
  15.    Loop
  16. End Sub
  17.  
  18. 'VOID CALLBACK TimerProc(
  19. '  __in  HWND hwnd,
  20. '  __in  UINT uMsg,
  21. '  __in  UINT_PTR idEvent,
  22. '  __in  DWORD dwTime
  23. ');
  24. Sub TimerProc(ByVal hwnd As Long, ByVal uMsg As Long, ByVal idEvent As Long, ByVal dwTime As Long)
  25.    ' hwnd   ----> { el pasado por parametro en SetTimer() }
  26.    ' uMsg   ---->  {   WM_TIMER = 275 }
  27.    ' idEvent ---->  { el retornado por SetTimer() }
  28.    Debug.Print hwnd, uMsg, idEvent; "{" &  iTmr & "}", dwTime
  29.    iTmr = ((Not KillTimer(hwnd, idEvent)) And &H1)
  30.    Debug.Print hwnd, uMsg, idEvent; "{" &  iTmr & "}", dwTime
  31. End Sub
  32.  
  33.  

temibles Lunas!¡.


Título: Re: obtener el hwnd de un programa sin form
Publicado por: Hasseds en 28 Agosto 2011, 19:40 pm
Cita de: BlackZeroX▓▓▒▒░░

Código
  1.  
  2. 'VOID CALLBACK TimerProc(
  3. '  __in  HWND hwnd,
  4. '  __in  UINT uMsg,
  5. '  __in  UINT_PTR idEvent,
  6. '  __in  DWORD dwTime
  7. ');
  8.  
  9.  


Mas claro Imposible !!!