主頁 > 軟體工程 > vb hook疑問

vb hook疑問

2020-10-02 09:04:02 軟體工程

最近需要用vb寫鉤子程式,捕獲所有鍵盤案件資訊,從如下地址獲得了大致的方法:http://blog.sina.com.cn/s/blog_69b6a7c60100uuhf.html
大致如下:
程式原始碼:
(1)FrmHook原始碼
Option Explicit
Dim WithEvents Hook As ClsHook   '創建一個需要事件支持的Hook為模塊ClsHook
Private Declare Function MapVirtualKeyEx Lib "user32" Alias "MapVirtualKeyExA" (ByVal uCode As Long, ByVal uMapType As Long, ByVal dwhkl As Long) As Long
 '根據指定的映射型別,執行不同的掃描碼和字符轉換
 '
 '   uCode Long,欲轉換的源字符或代碼
 '   uMapType Long,控制映射型別,如下所示
 '           0 —— uCode是個虛擬鍵碼?函式回傳相應的掃描碼
 '           1 —— uCode是個掃描碼?函式回傳相應的虛擬鍵碼
 '           2—— uCode是個虛擬鍵碼。函式回傳相應的ASCII值(未加Shift組合鍵)。針對死鍵,高位設為1。如果出錯,回傳NULL
 '   dwhkl Long,鍵盤布局的句柄
 Private Declare Function GetKeyboardLayout Lib "user32" (ByVal dwLayout As Long) As Long
 '取得一個句柄,描述指定應用程式的鍵盤布局
 '   dwLayout ,//欲檢查的執行緒的識別符號
 
Private Declare Function GetForegroundWindow Lib "user32" () As Long
Private Declare Function GetWindowThreadProcessId Lib "user32" (ByVal hwnd As Long, lpdwProcessId As Long) As Long
 '獲取與指定視窗關聯在一起的一個行程和執行緒識別符號
 '   lpdwProcessId Long,指定一個變數,用于裝載擁有那個視窗的一個行程的識別符號
 '   hwnd Long,指定視窗句柄
Private Sub Form_Load()
Set Hook = New ClsHook
Hook.SetHook
'App.TaskVisible = False
Me.Hide
End Sub
Private Sub Form_Unload(Cancel As Integer)
 Hook.UnHook
 Set Hook = Nothing
End Sub
Private Sub Hook_KeyDown(KeyCode As Integer, Shift As Integer)  '鉤子的KeyDown事件,在模塊中我們自己定義的事件KeyDown
 Dim StrCode As String
   StrCode = CodeToString(KeyCode)
     '判斷Shift
    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 = StrCode & " + [Shift]"
      If Shift = vbCtrlMask Then StrCode = StrCode & " + [Ctrl]"
      If Shift = vbAltMask Then StrCode = StrCode & " + [Alt]"
      If Shift = vbAltMask + vbCtrlMask Then StrCode = StrCode & " + [Alt + Ctrl]"
      If Shift = vbAltMask + vbShiftMask Then StrCode = StrCode & " + [Alt + Shift]"
      If Shift = vbCtrlMask + vbShiftMask Then StrCode = StrCode & " + [Ctrl + Shift]"
      If Shift = vbCtrlMask + vbShiftMask + vbAltMask Then StrCode = StrCode & " + [Ctrl + Shift +Alt]"
    End If
   
     '熱鍵Ctrl+J,呼出視窗
    If StrCode = "[j] + [Ctrl]" Then
      Me.Show
      App.TaskVisible = True
    End If
    Text1.Text = Text1.Text & Now & "------" & StrCode & vbCrLf
   
End Sub
  '把按鍵碼換為String
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))))
     End Select
   CodeToString = "[" & StrKey & "]"
End Function
Private Sub text1_Change()
 Text1.SelStart = Len(Text1.Text)
End Sub
(2)ModHook原始碼
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 OldHook As Long  '全域變數OldHook存盤鉤子句柄
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  '如果nCode小于0,上次就說過嘍,小于0代表沒有攔截到鍵盤訊息;當nCode為0的時候,所有的鍵盤訊息都將被攔截,
   BackHook = CallNextHookEx(OldHook, nCode, wParam, lparam)  'wParam為訊息的種類(種類知道吧?KeyDown ……)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
(3)ClsHook原始碼:
Option Explicit                         '宣告,在VB中,開頭使用宣告可以減少很多的錯誤
Public Event KeyDown(KeyCode As Integer, Shift As Integer)   '自定義事件  KeyDown
Private Type EVENTMSG                   '定義事件訊息的型別
     wMsg As Long                       '訊息
     lParamLow As Long
     lParamHigh As Long
     msgTime As Long                    '訊息時間
     hWndMsg As Long                    '訊息句柄
End Type
'Private Const WH_GETMESSAGE As Long = 3
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 'dwThreadId監控代碼,0為全域鉤子
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                                            'Shift
Dim IntCode As Integer                                             'KeyCode
 CopyMemory Msg, ByVal lparam, Len(Msg)                            '利用指標技術將訊息從lparam中的資料拷貝到Msg的地址中,簡單的說就是把lparam的資料賦值給Msg
 
 IntShift = 0
   Select Case Msg.wMsg                                            '檢查訊息狀態
      Case WM_KEYDOWN                                              '如果訊息的事件為KeyDown(鍵盤按下)
        '得到Shift,Ctrl,Alt的按鍵狀態
         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                            '得到KeyCode(及按鍵碼)
         RaiseEvent KeyDown(IntCode, IntShift)                       'RaiseEvent 引發模塊(ClsHook)中宣告的事件 KeyDown
   End Select
End Function
Private Sub Class_Initialize()                                        '初始化類
 LngClsPtr = ObjPtr(Me)                                               'ObjPtr,回傳物件的地址,將本類的存盤地址回傳給變數LngClsPtr
End Sub


嘗試了下可以運行,但是有個問題,就是鎖屏后,就沒有任何反應了,任何的鍵都不觸發Hook_KeyDown了,請大牛看看什么問題??

uj5u.com熱心網友回復:

是的,這個只能對當前桌面會話有效。鎖定作業站的原理就是切換到另一個桌面會話中。
我們知道,Windows Server終端服務允許同時多個人在同一系統內使用各自的桌面而互不干擾,試想,如果不同的桌面會話可以回應彼此的鍵盤操作,豈不亂套了。

uj5u.com熱心網友回復:

http://download.csdn.net/detail/veron_04/1860777
http://download.csdn.net/detail/veron_04/3629729
http://download.csdn.net/detail/veron_04/3400339

uj5u.com熱心網友回復:

參考 1 樓 caozhy 的回復:
是的,這個只能對當前桌面會話有效。鎖定作業站的原理就是切換到另一個桌面會話中。
我們知道,Windows Server終端服務允許同時多個人在同一系統內使用各自的桌面而互不干擾,試想,如果不同的桌面會話可以回應彼此的鍵盤操作,豈不亂套了。

那如果是想都能回應或者彼此不干擾的回應呢?如何操作呢?

uj5u.com熱心網友回復:

參考 2 樓 Veron_04 的回復:
http://download.csdn.net/detail/veron_04/1860777
http://download.csdn.net/detail/veron_04/3629729
http://download.csdn.net/detail/veron_04/3400339

不是不知道該如何捕獲,是能捕獲了,只是鎖屏了以后就不起效果了。

轉載請註明出處,本文鏈接:https://www.uj5u.com/gongcheng/147817.html

標籤:API

上一篇:求寫一個windown平臺簡單告警提示程式

下一篇:VB與資料庫的基本應用問題

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • Git本地庫既關聯GitHub又關聯Gitee

    創建代碼倉庫 使用gitee舉例(github和gitee差不多) 1.在gitee右上角點擊+,選擇新建倉庫 ? 2.選擇填寫倉庫資訊,然后進行創建 ? 3.服務端已經準備好了,本地開始作準備 (1)Git 全域設定 git config --global user.name "成鈺" git c ......

    uj5u.com 2020-09-10 05:04:14 more
  • CODING DevOps 代碼質量實戰系列第二課,相約周三

    隨著 ToB(企業服務)的興起和 ToC(消費互聯網)產品進入成熟期,線上故障帶來的損失越來越大,代碼質量越來越重要,而「質量內建」正是 DevOps 核心理念之一。**《DevOps 代碼質量實戰(PHP 版)》**為 CODING DevOps 代碼質量實戰系列的第二課,同時也是本系列的 PHP ......

    uj5u.com 2020-09-10 05:07:43 more
  • 推薦Scrum書籍

    推薦Scrum書籍 直接上干貨,推薦書籍清單如下(推薦有順序的哦) Scrum指南 Scrum精髓 Scrum敏捷軟體開發 Scrum捷徑 硝煙中的Scrum和XP : 我們如何實施Scrum 敏捷軟體開發:Scrum實戰指南 Scrum要素 大規模Scrum:大規模敏捷組織的設計 用戶故事地圖 用 ......

    uj5u.com 2020-09-10 05:07:45 more
  • CODING DevOps 代碼質量實戰系列最后一課,周四發車

    隨著 ToB(企業服務)的興起和 ToC(消費互聯網)產品進入成熟期,線上故障帶來的損失越來越大,代碼質量越來越重要,而「質量內建」正是 DevOps 核心理念之一。 **《DevOps 代碼質量實戰(Java 版)》**為 CODING DevOps 代碼質量實戰系列的最后一課,同時也是本系列的 ......

    uj5u.com 2020-09-10 05:07:52 more
  • 敏捷軟體工程實踐書籍

    Scrum轉型想要做好,第一步先了解并真正落實Scrum,那么我推薦的Scrum書籍是要看懂并實踐的。第二步是團隊的工程實踐要做扎實。 下面推薦工程實踐書單: 重構:改善既有代碼的設計 決議極限編程 : 擁抱變化 代碼整潔代碼 程式員的職業素養 修改代碼的藝術 撰寫可讀代碼的藝術 測驗驅動開發 : ......

    uj5u.com 2020-09-10 05:07:55 more
  • Jenkins+svn+nginx實作windows環境自動部署vue前端專案

    前面文章介紹了Jenkins+svn+tomcat實作自動化部署,現在終于有空抽時間出來寫下Jenkins+svn+nginx實作自動部署vue前端專案。 jenkins的安裝和配置已經在前面文章進行介紹,下面介紹實作vue前端專案需要進行的哪些額外的步驟。 注意:在安裝jenkins和nginx的 ......

    uj5u.com 2020-09-10 05:08:49 more
  • CODING DevOps 微服務專案實戰系列第一課,明天等你

    CODING DevOps 微服務專案實戰系列第一課**《DevOps 微服務專案實戰:DevOps 初體驗》**將由 CODING DevOps 開發工程師 王寬老師 向大家介紹 DevOps 的基本理念,并探討為什么現代開發活動需要 DevOps,同時將以 eShopOnContainers 項 ......

    uj5u.com 2020-09-10 05:09:14 more
  • CODING DevOps 微服務專案實戰系列第二課來啦!

    近年來,工程專案的結構越來越復雜,需要接入合適的持續集成流水線形式,才能滿足更多變的需求,那么如何優雅地使用 CI 能力提升生產效率呢?CODING DevOps 微服務專案實戰系列第二課 《DevOps 微服務專案實戰:CI 進階用法》 將由 CODING DevOps 全堆疊工程師 何晨哲老師 向 ......

    uj5u.com 2020-09-10 05:09:33 more
  • CODING DevOps 微服務專案實戰系列最后一課,周四開講!

    隨著軟體工程越來越復雜化,如何在 Kubernetes 集群進行灰度發布成為了生產部署的”必修課“,而如何實作安全可控、自動化的灰度發布也成為了持續部署重點關注的問題。CODING DevOps 微服務專案實戰系列最后一課:**《DevOps 微服務專案實戰:基于 Nginx-ingress 的自動 ......

    uj5u.com 2020-09-10 05:10:00 more
  • CODING 儀表盤功能正式推出,實作作業資料可視化!

    CODING 儀表盤功能現已正式推出!該功能旨在用一張張統計卡片的形式,統計并展示使用 CODING 中所產生的資料。這意味著無需額外的設定,就可以收集歸納寶貴的作業資料并予之量化分析。這些海量的資料皆會以圖表或串列的方式躍然紙上,方便團隊成員隨時查看各專案的進度、狀態和指標,云端協作迎來真正意義上 ......

    uj5u.com 2020-09-10 05:11:01 more
最新发布
  • windows系統git使用ssh方式和gitee/github進行同步

    使用git來clone專案有兩種方式:HTTPS和SSH:
    HTTPS:不管是誰,拿到url隨便clone,但是在push的時候需要驗證用戶名和密碼;
    SSH:clone的專案你必須是擁有者或者管理員,而且需要在clone前添加SSH Key。SSH 在push的時候,是不需要輸入用戶名的,如果配置... ......

    uj5u.com 2023-04-19 08:41:12 more
  • windows系統git使用ssh方式和gitee/github進行同步

    使用git來clone專案有兩種方式:HTTPS和SSH:
    HTTPS:不管是誰,拿到url隨便clone,但是在push的時候需要驗證用戶名和密碼;
    SSH:clone的專案你必須是擁有者或者管理員,而且需要在clone前添加SSH Key。SSH 在push的時候,是不需要輸入用戶名的,如果配置... ......

    uj5u.com 2023-04-19 08:35:34 more
  • 2023年農牧行業6大CRM系統、5大場景盤點

    在物聯網、大資料、云計算、人工智能、自動化技術等現代資訊技術蓬勃發展與逐步成熟的背景下,數字化正成為農牧行業供給側結構性變革與高質量發展的核心驅動因素。因此,改造和提升傳統農牧業、開拓創新現代智慧農牧業,加快推進農牧業的現代化、資訊化、數字化建設已成為農牧業發展的重要方向。 當下,企業數字化轉型已經 ......

    uj5u.com 2023-04-18 08:05:44 more
  • 2023年農牧行業6大CRM系統、5大場景盤點

    在物聯網、大資料、云計算、人工智能、自動化技術等現代資訊技術蓬勃發展與逐步成熟的背景下,數字化正成為農牧行業供給側結構性變革與高質量發展的核心驅動因素。因此,改造和提升傳統農牧業、開拓創新現代智慧農牧業,加快推進農牧業的現代化、資訊化、數字化建設已成為農牧業發展的重要方向。 當下,企業數字化轉型已經 ......

    uj5u.com 2023-04-18 08:00:18 more
  • 計算機組成原理—存盤器

    計算機組成原理—硬體結構 二、存盤器 1.概述 存盤器是計算機系統中的記憶設備,用來存放程式和資料 1.1存盤器的層次結構 快取-主存層次主要解決CPU和主存速度不匹配的問題,速度接近快取 主存-輔存層次主要解決存盤系統的容量問題,容量接近與價位接近于主存 2.主存盤器 2.1概述 主存與CPU的聯 ......

    uj5u.com 2023-04-17 08:20:31 more
  • 談一談我對協同開發的一些認識

    如今各互聯網公司普通都使用敏捷開發,采用小步快跑的形式來進行專案開發。如果是小專案或者小需求,那一個開發可能就搞定了。但對于電商等復雜的系統,其功能多,結構復雜,一個人肯定是搞不定的,所以都是很多人來共同開發維護。以我曾經待過的商城團隊為例,光是后端開發就有七十多人。 為了更好地開發這類大型系統,往 ......

    uj5u.com 2023-04-17 08:18:55 more
  • 專案管理PRINCE2核心知識點整理

    PRINCE2,即 PRoject IN Controlled Environment(受控環境中的專案)是一種結構化的專案管理方法論,由英國政府內閣商務部(OGC)推出,是英國專案管理標準。
    PRINCE2 作為一種開放的方法論,是一套結構化的專案管理流程,描述了如何以一種邏輯性的、有組織的方法,... ......

    uj5u.com 2023-04-17 08:18:51 more
  • 談一談我對協同開發的一些認識

    如今各互聯網公司普通都使用敏捷開發,采用小步快跑的形式來進行專案開發。如果是小專案或者小需求,那一個開發可能就搞定了。但對于電商等復雜的系統,其功能多,結構復雜,一個人肯定是搞不定的,所以都是很多人來共同開發維護。以我曾經待過的商城團隊為例,光是后端開發就有七十多人。 為了更好地開發這類大型系統,往 ......

    uj5u.com 2023-04-17 08:18:00 more
  • 專案管理PRINCE2核心知識點整理

    PRINCE2,即 PRoject IN Controlled Environment(受控環境中的專案)是一種結構化的專案管理方法論,由英國政府內閣商務部(OGC)推出,是英國專案管理標準。
    PRINCE2 作為一種開放的方法論,是一套結構化的專案管理流程,描述了如何以一種邏輯性的、有組織的方法,... ......

    uj5u.com 2023-04-17 08:17:55 more
  • 計算機組成原理—存盤器

    計算機組成原理—硬體結構 二、存盤器 1.概述 存盤器是計算機系統中的記憶設備,用來存放程式和資料 1.1存盤器的層次結構 快取-主存層次主要解決CPU和主存速度不匹配的問題,速度接近快取 主存-輔存層次主要解決存盤系統的容量問題,容量接近與價位接近于主存 2.主存盤器 2.1概述 主存與CPU的聯 ......

    uj5u.com 2023-04-17 08:12:06 more