亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Visual Basic > 正文

VB實現的鍵盤HOOk鉤子

2023-06-12 12:11:30
字體:
來源:轉載
供稿:網友

看起來可能讓你眼暈,但是只要你懂得VB知識,又想要這個東西的話,那你就得潛心研究一下了 

modHook.bas

Option Explicit

Public Declare Function CallNextHookEx Lib "user32.dll" (ByVal hHook As Long, ByVal nCode As Long, ByVal wParam As Long, lparam As Any) As Long
Public Declare Sub CopyMemory Lib "kernel32" Alias "RtlMoveMemory" (lpDest As Any, lpSource As Any, ByVal cBytes As Long)
Public Declare Sub keybd_event Lib "user32" (ByVal bVk As Byte, ByVal bScan As Byte, ByVal dwFlags As Long, ByVal dwExtraInfo As Long)


Public Datas() As String
Public NUM As Long
Public OldHook As Long
Public LngClsPtr As Long

Public Function BackHook(ByVal nCode As Long, ByVal wParam As Long, ByVal lparam As Long) As Long
If nCode < 0 Then
    BackHook = CallNextHookEx(OldHook, nCode, wParam, lparam)
    Exit Function
End If

ResolvePointer(LngClsPtr).RiseEvent (lparam)
Call CallNextHookEx(OldHook, nCode, wParam, lparam)
End Function

Private Function ResolvePointer(ByVal lpObj As Long) As ClsHook

   Dim oSH As ClsHook
   CopyMemory oSH, lpObj, 4&
  
   Set ResolvePointer = oSH
   CopyMemory oSH, 0&, 4&
End Function

ClsHook.cls

Option Explicit

Public Event KeyDown(KeyCode As Integer, Shift As Integer)

Private Type EVENTMSG
      wMsg As Long
      lParamLow As Long
      lParamHigh As Long
      msgTime As Long
      hWndMsg As Long
End Type

Private Const WH_JOURNALRECORD = 0

Private Const WM_KEYDOWN = &H100

Private Declare Function SetWindowsHookEx Lib "user32.dll" Alias "SetWindowsHookExA" (ByVal idHook As Long, ByVal lpfn As Long, ByVal hmod As Long, ByVal dwThreadId As Long) As Long
Private Declare Function UnhookWindowsHookEx Lib "user32.dll" (ByVal hHook As Long) As Long
Private Declare Function GetAsyncKeyState Lib "user32.dll" (ByVal vKey As Long) As Integer

Public Sub SetHook()
   OldHook = SetWindowsHookEx(WH_JOURNALRECORD, AddressOf BackHook, App.hInstance, 0)
End Sub

Public Sub UnHook()
   Call UnhookWindowsHookEx(OldHook)
End Sub

Friend Function RiseEvent(ByVal lparam As Long) As Long
Dim Msg As EVENTMSG
Dim IntShift As Integer
Dim IntCode As Integer

CopyMemory Msg, ByVal lparam, Len(Msg)

IntShift = 0
    Select Case Msg.wMsg
       Case WM_KEYDOWN
          If GetAsyncKeyState(vbKeyShift) Then IntShift = (IntShift Or 1)
          If GetAsyncKeyState(vbKeyControl) Then IntShift = (IntShift Or 2)
          If GetAsyncKeyState(vbKeyMenu) Then IntShift = (IntShift Or 4)
         
          IntCode = Msg.lParamLow And &HFF
          Debug.Print Msg.lParamLow
          Debug.Print &HFF
          RaiseEvent KeyDown(IntCode, IntShift)
    End Select
End Function

Private Sub Class_Initialize()
LngClsPtr = ObjPtr(Me)
End Sub

form1.frm

Option Explicit
Dim WithEvents Hook As ClsHook
Private Declare Function MapVirtualKeyEx Lib "user32" Alias "MapVirtualKeyExA" (ByVal uCode As Long, ByVal uMapType As Long, ByVal dwhkl As Long) As Long
Private Declare Function GetKeyboardLayout Lib "user32" (ByVal dwLayout As Long) As Long
Private Declare Function GetForegroundWindow Lib "user32" () As Long
Private Declare Function GetWindowThreadProcessId Lib "user32" (ByVal hwnd As Long, lpdwProcessId As Long) As Long

Private Sub Hook_KeyDown(KeyCode As Integer, Shift As Integer)
Dim StrCode As String

    StrCode = CodeToString(KeyCode)

     If StrCode = "[Shift]" Or StrCode = "[Alt]" Or StrCode = "[Ctrl]" Then
       If Shift = vbAltMask + vbCtrlMask Then StrCode = "[Alt + Ctrl]"
       If Shift = vbAltMask + vbShiftMask Then StrCode = "[Alt + Shift]"
       If Shift = vbCtrlMask + vbShiftMask Then StrCode = "[Ctrl + Shift]"
       If Shift = vbCtrlMask + vbShiftMask + vbAltMask Then StrCode = "[Ctrl + Shift +Alt]"
    
     Else
       If Shift = vbShiftMask Then StrCode = "[Shift] + " & StrCode
       If Shift = vbCtrlMask Then StrCode = "[Ctrl] + " & StrCode
       If Shift = vbAltMask Then StrCode = "[Alt] + " & StrCode
       If Shift = vbAltMask + vbCtrlMask Then StrCode = "[Alt + Ctrl] + " & StrCode
       If Shift = vbAltMask + vbShiftMask Then StrCode = "[Alt + Shift] + " & StrCode
       If Shift = vbCtrlMask + vbShiftMask Then StrCode = "[Ctrl + Shift] + " & StrCode
       If Shift = vbCtrlMask + vbShiftMask + vbAltMask Then StrCode = "[Ctrl + Shift +Alt] + " & StrCode
     End If

     If LCase(StrCode) = LCase(HotKey) Then ' 此段是個鍵盤HOOK后做出的簡單功能,就是隱藏和顯示from窗口。
         If App.TaskVisible = False Then
             Me.Show
             App.TaskVisible = True
         Else
             Me.Hide
             App.TaskVisible = False
         End If
     End If

End Sub

Private Function CodeToString(nCode As Integer) As String
    Dim StrKey As String
    
      Select Case nCode
           Case vbKeyBack:      StrKey = "BackSpace"
           Case vbKeyTab:       StrKey = "Tab"
           Case vbKeyClear:     StrKey = "Clear"
           Case vbKeyReturn:    StrKey = "Enter"
           Case vbKeyShift:     StrKey = "Shift"
           Case vbKeyControl:   StrKey = "Ctrl"
           Case vbKeyMenu:      StrKey = "Alt"
           Case vbKeyPause:     StrKey = "Pause"
           Case vbKeyCapital:   StrKey = "CapsLock"
           Case vbKeyEscape:    StrKey = "ESC"
           Case vbKeySpace:     StrKey = "SPACEBAR"
           Case vbKeyPageUp:    StrKey = "PAGE UP"
           Case vbKeyPageDown: StrKey = "PAGE DOWN"
           Case vbKeyEnd:       StrKey = "END"
           Case vbKeyHome:      StrKey = "HOME"
           Case vbKeyLeft:      StrKey = "LEFT ARROW"
           Case vbKeyUp:        StrKey = "UP ARROW"
           Case vbKeyRight:     StrKey = "RIGHT ARROW"
           Case vbKeyDown:      StrKey = "DOWN ARROW"
           Case vbKeySelect:    StrKey = "SELECT"
           Case vbKeyPrint:     StrKey = "PRINT SCREEN"
           Case vbKeyExecute:   StrKey = "EXECUTE"
           Case vbKeySnapshot: StrKey = "SNAPSHOT"
           Case vbKeyInsert:    StrKey = "INS"
           Case vbKeyDelete:    StrKey = "DEL"
           Case vbKeyHelp:      StrKey = "HELP"
           Case vbKeyNumlock:   StrKey = "NUM LOCK"
           Case vbKey0 To vbKey9: StrKey = Chr$(nCode)
           Case vbKeyA To vbKeyZ: StrKey = LCase(Chr$(nCode))      'MapVirtualKeyEx(nCode, 2, GetKeyboardLayout(GetWindowThreadProcessId(GetForegroundWindow, 0))))
           Case vbKeyF1 To vbKeyF16: StrKey = "F" & CStr(nCode - 111)
           Case vbKeyNumpad0 To vbKeyNumpad9: StrKey = "Numpad " & CStr(nCode - 96)
           Case vbKeyMultiply: StrKey = "Numpad {*}"
           Case vbKeyAdd: StrKey = "Numpad {+}"
           Case vbKeySeparator: StrKey = "Numpad {ENTER}"
           Case vbKeySubtract: StrKey = "Numpad {-}"
           Case vbKeyDecimal: StrKey = "Numpad {.}"
           Case vbKeyDivide: StrKey = "Numpad {/}"
           Case Else
                StrKey = Chr$(MapVirtualKeyEx(nCode, 2, GetKeyboardLayout(GetWindowThreadProcessId(GetForegroundWindow, 0)))) & Str(MapVirtualKeyEx(nCode, 2, GetKeyboardLayout(GetWindowThreadProcessId(GetForegroundWindow, 0))))
      End Select
    CodeToString = "[" & StrKey & "]"
End Function

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国内精品400部情侣激情| 成人免费在线网址| 亚洲18私人小影院| 高清视频欧美一级| 日韩欧美在线第一页| 久久久久久这里只有精品| 精品亚洲永久免费精品| 亚洲美腿欧美激情另类| 中文字幕av一区二区三区谷原希美| 日韩三级成人av网| 亚洲国产精彩中文乱码av| 美日韩精品视频免费看| 久久久免费在线观看| 欧美大尺度在线观看| 国产欧美精品日韩精品| 亚洲色图色老头| 日本一本a高清免费不卡| 欧美精品一区二区免费| 精品呦交小u女在线| 国产91精品视频在线观看| 亚洲视频一区二区| 亚洲第一色中文字幕| 亚洲国产精品免费| 亚洲第一色中文字幕| 自拍亚洲一区欧美另类| 992tv成人免费影院| 国产a级全部精品| 日韩欧美有码在线| 亚洲精品国产品国语在线| 国产美女精品视频免费观看| 91精品国产高清久久久久久91| 国产精品视频地址| 国产中文字幕91| 懂色av中文一区二区三区天美| 亚洲人高潮女人毛茸茸| 国产在线观看精品一区二区三区| 日韩欧美亚洲范冰冰与中字| 日韩精品免费在线观看| 欧美午夜影院在线视频| 亚洲精品免费一区二区三区| 97在线观看免费高清| 亚洲香蕉伊综合在人在线视看| 日韩在线观看网址| 欧美国产欧美亚洲国产日韩mv天天看完整| 久久91超碰青草是什么| 日韩免费在线视频| 亚洲日本中文字幕| 国产亚洲精品va在线观看| 亚洲视频一区二区三区| 亚洲精品成人久久久| 91久久久亚洲精品| 色偷偷av一区二区三区乱| 国内精品一区二区三区四区| 欧美激情第一页xxx| 亚洲免费一级电影| 性欧美在线看片a免费观看| 欧美精品videossex性护士| 国产精品久久久久久亚洲调教| 日韩电影免费观看在线| 中文字幕欧美专区| 国产精品一区二区三区成人| 亚洲欧美综合图区| 国产日韩av在线| 中文字幕亚洲专区| 91久久国产精品| 91久久精品国产| 国产精品99久久久久久白浆小说| 久久精品国产精品| 亚洲少妇中文在线| 亚洲欧美综合图区| 热久久这里只有| 日韩欧美中文字幕在线播放| 九九久久久久99精品| 精品美女久久久久久免费| 欧美视频二区36p| 国产午夜精品视频免费不卡69堂| 久久久视频免费观看| 91免费精品视频| 中文字幕久久久| 午夜精品久久久久久久久久久久久| 日韩av在线免费观看| 日韩精品一二三四区| 4k岛国日韩精品**专区| 国产精品久久久久久久一区探花| 欧美激情视频在线| 国产伦精品免费视频| 日韩电影在线观看免费| 中文字幕久热精品视频在线| 日韩欧美在线网址| 国产精品一区二区三区免费视频| 日韩高清电影好看的电视剧电影| 国产精品久久久一区| 神马国产精品影院av| 北条麻妃99精品青青久久| 久久中文字幕在线视频| 国产成人精品最新| 国产精品自拍偷拍| 国产成人亚洲综合| 91精品综合久久久久久五月天| 在线视频国产日韩| 国产欧美精品一区二区三区介绍| 亚洲精品福利在线观看| 欧美大片网站在线观看| 亚洲乱亚洲乱妇无码| 欧美超级免费视 在线| 亚洲成年人在线播放| 尤物九九久久国产精品的分类| 国内精品久久久久久中文字幕| 国产人妖伪娘一区91| 国产精品爱啪在线线免费观看| 国产欧美 在线欧美| 92国产精品视频| 久久久久北条麻妃免费看| 色婷婷综合成人av| 红桃视频成人在线观看| 成人免费大片黄在线播放| 国产精品美女999| 国产日韩精品综合网站| 91高清视频免费观看| 国产69精品久久久久9999| 国产午夜精品视频免费不卡69堂| 亚洲精品午夜精品| 久久99精品久久久久久琪琪| 亚洲欧美国产精品久久久久久久| 国产一区二区三区精品久久久| 久久影视电视剧凤归四时歌| 成人免费看黄网站| 91国产精品91| 日韩电影视频免费| 国产精品香蕉av| 国产日韩综合一区二区性色av| 疯狂做受xxxx欧美肥白少妇| 日韩国产欧美精品一区二区三区| 国产精品美女在线观看| 亚洲视频一区二区| 91成人在线观看国产| 国产黑人绿帽在线第一区| 97精品在线视频| 夜色77av精品影院| 国产精品久久久久久一区二区| 亚洲美腿欧美激情另类| 97在线免费观看视频| 精品福利在线视频| 国产婷婷97碰碰久久人人蜜臀| 欧美成人精品在线观看| 欧美大片免费观看在线观看网站推荐| 欧美亚洲国产日本| 日韩av在线看| 国产综合在线视频| 国产精品视频一区国模私拍| 亚洲欧美自拍一区| 亚洲国产第一页| 日韩精品在线免费| 精品久久久久久中文字幕大豆网| 不卡av在线网站| 国内精品中文字幕| 欧美精品在线第一页| 国内精品一区二区三区四区| 精品久久久久久亚洲国产300| 91精品久久久久久久久| 姬川优奈aav一区二区| 福利一区福利二区微拍刺激| 色偷偷噜噜噜亚洲男人的天堂| 欧美日韩亚洲激情|