當前位置:編程學習大全網 - 源碼下載 - 求API Hook 例子(VB的)

求API Hook 例子(VB的)

我2年前從網上瘋狂搜索找到的全局鍵盤鉤子的代碼,當時研究了壹下,反正是VB都沒學全的菜鳥,頭都暈了,到最後總算得了個知其然,當時自己用來編了壹個攔截組合鍵並實行操作的程序。幸好鉤子部分的代碼還保存著,給妳研究研究吧:

'|------------------------------|

'|下面是全局鍵盤鉤子程序段的聲明|

'|------------------------------|

Public LocalhHook As Long '局部鍵盤鉤子變量

Public m_hDllKbdHook As Long '全局鍵盤鉤子變量

Public Const WH_KEYBOARD_LL As Long = 13 'enables monitoring of keyboard

'input events about to be posted

'in a thread input queue

Public Const WM_KEYDOWN = &H100

Public Const WM_SYSKEYDOWN = &H104

Private Const HC_ACTION As Long = 0 'wParam and lParam parameters

'contain information about a 'keyboard message

Private Const VK_CONTROL = &H11 'virtual key constants

Private Const VK_ESCAPE = &H1B

Private Const VK_F1 = &H70

Private Const VK_F2 = &H71

Private Const VK_F3 = &H72

Private Const VK_F4 = &H73

Private Const LLKHF_EXTENDED = &H1& 'test the extended-key flag

Private Const LLKHF_INJECTED = &H10& 'test the event-injected flag

Private Const LLKHF_ALTDOWN = &H20& 'test the context code

Private Const LLKHF_UP As Long = &H80

Public Type KeyboardBytes

kbByte(0 To 255) As Byte

End Type

Private Type KBDLLHOOKSTRUCT

vkCode As Long 'a virtual-key code in the range 1 to 254

scanCode As Long 'hardware scan code for the key

flags As Long 'specifies the extended-key flag,

'event-injected flag, context code,

'and transition-state flag

time As Long 'time stamp for this message

dwExtraInfo As Long 'extra info associated with the message

End Type

Public Declare Function SetWindowsHookEx Lib "user32" _

Alias "SetWindowsHookExA" _

(ByVal idHook As Long, _

ByVal lpfn As Long, _

ByVal hmod As Long, _

ByVal dwThreadId As Long) As Long

Public Declare Function UnhookWindowsHookEx Lib "user32" _

(ByVal hHook As Long) As Long

Public Declare Function CallNextHookEx Lib "user32" _

(ByVal hHook As Long, _

ByVal nCode As Long, _

ByVal wParam As Long, _

ByVal lParam As Long) As Long

Public Declare Sub CopyMemory Lib "kernel32" _

Alias "RtlMoveMemory" _

(pDest As Any, _

pSource As Any, _

ByVal cb As Long)

Public Declare Function GetKeyboardState Lib "user32" _

(kbArray As KeyboardBytes) As Long

Public Declare Function GetKeyState Lib "user32" _

(ByVal nVirtKey As Long) As Integer

Private Declare Function GetAsyncKeyState Lib "user32" _

(ByVal vKey As Long) As Integer

'\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\

'

'下面的是全局鍵盤鉤子程序段的代碼

'

'\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\

Public Function LowLevelKeyboardProc(ByVal nCode As Long, _

ByVal wParam As Long, _

ByVal lParam As Long) As Long

Static kbdllhs As KBDLLHOOKSTRUCT

If nCode = HC_ACTION Then

If wParam = WM_KEYDOWN Or wParam = WM_SYSKEYDOWN Then

Call CopyMemory(kbdllhs, ByVal lParam, Len(kbdllhs))

'F1 --------------

If kbdllhs.vkCode = VK_F1 Then

If Form1.Text1(0).Text = "" Then

LowLevelKeyboardProc = 0 '值為 0 表示不攔截該信息

Exit Function

Else

LowLevelKeyboardProc = 1 '值為 1 表示攔截該信息

Clipboard.Clear '清空剪貼板

Clipboard.SetText (Form1.Text1(0).Text)

SendKeys "^(V)" '向當前活動窗口發送 Ctrl+V 組合鍵

Exit Function

End If

End If 'kbdllhs.vkCode = VK_F1

'F2 --------------

If kbdllhs.vkCode = VK_F2 Then

If Form1.Text1(1).Text = "" Then

LowLevelKeyboardProc = 0

Exit Function

Else

LowLevelKeyboardProc = 1

Clipboard.Clear

Clipboard.SetText (Form1.Text1(1).Text)

SendKeys "^(V)"

Exit Function

End If

End If 'kbdllhs.vkCode = VK_F2

'F3 --------------

If kbdllhs.vkCode = VK_F3 Then

If Form1.Text1(2).Text = "" Then

LowLevelKeyboardProc = 0

Exit Function

Else

LowLevelKeyboardProc = 1

Clipboard.Clear

Clipboard.SetText (Form1.Text1(2).Text)

SendKeys "^(V)"

Exit Function

End If

End If 'kbdllhs.vkCode = VK_F3

End If 'wParam = WM_KEYDOWN Or wParam = WM_SYSKEYDOWN

End If 'nCode = HC_ACTION

LowLevelKeyboardProc = CallNextHookEx(m_hDllKbdHook, nCode, wParam, lParam)

End Function

========補充壹下,實現全局鍵盤hook的代碼就這麽多了=======

上面的全是模塊裏面的代碼,下面的是Form裏面的代碼

Private Sub Form_Load()

Dim kbdState As KeyboardBytes

'裝載鉤子

Call GetKeyboardState(kbdState)

'set and obtain the handle to the keyboard hook

m_hDllKbdHook = SetWindowsHookEx(WH_KEYBOARD_LL, AddressOf LowLevelKeyboardProc, App.hInstance, 0&)

If m_hDllKbdHook = 0 Then

MsgBox "Failed to install low-level keyboard hook."

End If

End Sub

'還有卸載鉤子的:

Private Sub Form_QueryUnload(Cancel As Integer, UnloadMode As Integer)

If m_hDllKbdHook <> 0 Then

Call UnhookWindowsHookEx(m_hDllKbdHook)

End If

End Sub

  • 上一篇:2018-05-27 Spring攔截器和Skywalking沖突
  • 下一篇:哪個網站有免費的AutoCAD實例教程可以看?
  • copyright 2024編程學習大全網