• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            S.l.e!ep.¢%

            像打了激速一樣,以四倍的速度運轉,開心的工作
            簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
            posts - 1098, comments - 335, trackbacks - 0, articles - 1
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            利用鉤子機制取得Windows的消息監控權

            Posted on 2010-01-08 11:00 S.l.e!ep.¢% 閱讀(486) 評論(1)  編輯 收藏 引用 所屬分類: RootKit

            我們知道,Windows系統是建立在消息傳遞機制基礎上的,幾乎所有的程序活動都由消息來驅動。Windows的鉤子機制可以看作是一個消息中轉站,控制系統發出消息的處理和傳遞,利用鉤子,我們可以截獲系統發給應用程序的消息,經過處理后決定是否將消息再發給下一個應用程序。

            利用鉤子的這一特性,我們可以創建一個監控程序,用來收集和控制系統發出的消息。

             

            ■編制Windows鉤子程序

             


            ■編制Windows鉤子程序

             

            編制Windows的鉤子程序,需要用到幾個SDK中的API函數。下面列出這幾個函數的原型及說明:

            HHOOK SetWindowsHookEx( int idHook,HOOK_PROC lpfn,HINSTANCE hMod,DWORD dwThreadID);

            參數說明如下:

            idHook:鉤子的類型

            lpfn:鉤子處理函數地址

            hMod:包含鉤子函數的模塊句柄

            dwThreadID:鉤子的監控線程

            函數說明:函數將在系統中掛上一個由idHook指定類型的鉤子,監控并處理相應的特定消息。

            BOOL UnhookWindowsHookEx(HHOOK hhk);

            函數說明:函數將撤銷由hhk指定的鉤子。

            LRESULT CallNextHookEx( HHOOK hhk, int nCode,WPARAM wParam,LPARAM lParam );

            函數說明:函數將消息向下傳遞,下一個鉤子處理將截獲這一消息。

            由于鉤子的處理涉及到模塊及進程間的數據地址問題,一般情況是把鉤子整合到一個動態鏈接庫(DLL)中,并設立一個全局數據共享數據段,以存貯一些全局變量,保留上次鉤子消息事件發生時的狀態。全局共享數據段可以用如下的格式定義:

            #pragma data_seg("PublicData")

            HHOOK hhook=NULL;

            //全局共享數據

            #pragma data_seg()

            本文的范例程序演示了如何編制一個鼠標鉤子(WH_MOUSE)程序,其它類型的鉤子程序的編寫過程與范例程序類似。

             

            ■范例程序的建立與代碼分析

             


            ■范例程序的建立與代碼分析

             

            建立鉤子程序時需要把鉤子處理整合到動態鏈接庫中,所以例程中需要建立兩個Project。

            1.建立鉤子處理動態鏈接庫

            (1) 選擇MFC AppWizard(DLL)創建一個新Project,命名為“Spy”。

            (2) 選擇MFC Extension DLL類型。

            (3)創建一個新的頭文件,命名為“Hook.h”,修改它的代碼如下:

            extern "C" LRESULT CALLBACK MouseProc(int code,

            WPARAM wParam,LPARAM lParam); //鉤子處理函數

            extern "C" BOOL WINAPI StartHook();

            //啟動鉤子函數

            extern "C" BOOL WINAPI StopHook();

            //撤銷鉤子函數

            extern "C" int WINAPI GetResult();

            //取得鼠標單擊次數的函數

            (4)修改Spy.cpp程序代碼如下:

            #include "stdafx.h"

            #include 〈afxdllx.h〉

            #include "spyhook.h"

            ……

            //省略部分機器生成代碼

            #pragma data_seg("PublicData")

            //定義全局數據段

            HHOOK hhook=NULL;

            //鉤子句柄

            HINSTANCE pInstance=NULL;

            //鉤子模塊句柄

            UINT MouseClick=0;

            //記錄鼠標單擊次數的變量

            #pragma data_seg()

            ……

            //省略部分機器生成代碼

            extern "C" int APIENTRY

            DllMain(HINSTANCE hInstance, DWORD dwReason, LPVOID lpReserved)

            {

            if (dwReason = = DLL_PROCESS_ATTACH)

            {……

            //省略部分機器生成代碼

            new CDynLinkLibrary(SpyDLL);

            pInstance=hInstance;

            //取得模塊句柄

            }

            else if (dwReason = = DLL_PROCESS_DETACH)

            {

            TRACE0("SPY.DLL Terminating!\n");

            AfxTermExtensionModule(SpyDLL);

            }

            return 1;

            }

            extern "C" LRESULT CALLBACK MouseProc(int code,WPARAM wParam,LPARAM lParam)

            //鉤子處理函數

            {

            if (code 〈 0)

            //若code〈0,則直接調用CallNextHookEx返回

            return CallNextHookEx(hhook, code, wParam, lParam);

            if(wParam= =WM_LBUTTONDOWN)

            {MouseClick++;

            //記錄鼠標單擊次數

            }

            return CallNextHookEx(hhook, code, wParam,lParam);

            }

            extern "C" BOOL WINAPI StartHook()

            //啟動鉤子函數

            {

            hhook=SetWindowsHookEx(WH_MOUSE,MouseProc,pInstance,0);

            //掛上鉤子

            if(hhook!=NULL)

            return TRUE;

            else return FALSE;

            }

            extern "C" BOOL WINAPI StopHook()

            //撤銷鉤子函數

            {

            return UnhookWindowsHookEx(hhook);

            //撤銷鉤子

            }

            extern "C" int WINAPI GetResult()

            //返回鼠標單擊次數

            {

            return MouseClick;

            }

            (5)修改Spy.def程序代碼如下:

            LIBRARY "SPY"

            DESCRIPTION 'SPY Windows Dynamic Link Library'

            EXPORTS

            StartHookb @1

            StopHook @2

            GetResult @3

            (6)編譯Project,生成Spy.dll文件和Spy.Lib文件。

            2.建立使用鉤子的應用程序

            (1) 生成一個單文檔的可執行文件(EXE)的Project。

            (2) 修改資源中的主選單,增加一個選單項“監控”,下有三個子選單項,分別為“啟動”、“撤銷”和“取出”。

            (3) 在Project中加入Spy.Lib文件和Hook.h文件。

            (4) 分別修改“啟動”、“撤銷”和“取出”選單項的Command響應函數如下:

            #include "hook.h"

            ……//省略部分機器生成代碼

            void CMainFrame::OnStartSpy()

            //“啟動”選單項的響應函數

            {

            StartHook();

            }

            void CMainFrame::OnReleaseSpy()

            //“撤銷”選單項的響應函數

            {

            StopHook();

            }

            void CMainFrame::OnGet()

            //“取出”選單項的響應函數

            {

            int Result=GetResult();

            char buffer[40];

            wsprintf(buffer,"在程序運行期間,你共單擊鼠標%d次",Result);

            ::MessageBox(this-〉m_hWnd,buffer,"Message",MB_OK);

            }

            編譯這個Project,并把Spy.dll放到生成的可執行文件目錄下,便可運行程序。

            運行時,選擇“監控”選單中的“啟動”選單項,鉤子便開始工作,監視鼠標的活動情況;選擇“撤銷”選單項,系統便撤銷鉤子;選擇“取出”選單項,程序便報告在監控期間,用戶單擊鼠標左鍵的次數。

            以上程序在Windows 98,Visual C++ 4.0環境下成功運行。


            本文來自CSDN博客,轉載請標明出處:http://blog.csdn.net/i_like_cpp/archive/2005/05/03/371297.aspx

            Feedback

            # re: 利用鉤子機制取得Windows的消息監控權[未登錄]  回復  更多評論   

            2010-01-09 18:57 by C++
            招聘:C++程序員

            職位描述:

            1、技術人員職位,在上級的領導和監督下定期完成量化的工作要求;
            2、參與公司軟件項目平臺程序的設計和開發
            3、根據開發進度和任務分配,完成平臺相應模塊的設計、開發、編程任務;
            4、進行程序單元、功能的測試,查出軟件存在的缺陷并保證其質量;

            要求:

            1、熟悉Windows C++/MFC編程;
            2、熟悉一種大型關系型數據庫如Sql Server或Oracle的應用。
            3、掌握TCP/IP、多線程開發等;
            4、遵守職業道德,嚴守工作紀律,勤于鉆研,勇于進取,具有良好的團隊合作精神;
            5、兩年以上軟件開發經驗;
            熟悉休閑、棋牌類游戲開發經驗者優先。
            6、注意:待遇是根據能力浮動面議詳談。

            應屆畢業生或無相關經驗者,請勿擾,謝謝!

            工作地點:廣東湛江

            備注:為了提高您的面試機會,請不要直接在網上應聘,請把簡歷發送至linhang518@163.com,謝謝!#~
            久久精品国产99久久久古代| 久久99精品综合国产首页| 久久精品中文字幕一区| 精品99久久aaa一级毛片| 久久久艹| 99久久精品日本一区二区免费 | 久久久久九国产精品| 久久免费99精品国产自在现线| 亚洲第一永久AV网站久久精品男人的天堂AV | 91久久婷婷国产综合精品青草 | 国产精品免费久久久久电影网| 国产69精品久久久久9999APGF| 国产精品美女久久久| 老司机午夜网站国内精品久久久久久久久| 欧美一区二区久久精品| 国产精品视频久久| 国产毛片欧美毛片久久久| 一本伊大人香蕉久久网手机| 7777精品久久久大香线蕉| 久久久精品久久久久久| 久久综合综合久久综合| 久久综合九色欧美综合狠狠 | 久久婷婷是五月综合色狠狠| 久久久久久久尹人综合网亚洲| 狠狠色丁香久久婷婷综合_中| 久久综合狠狠综合久久激情 | 无码国产69精品久久久久网站| 一97日本道伊人久久综合影院| 国产高潮久久免费观看| 久久99国产精品一区二区| 久久人妻少妇嫩草AV无码专区| 777午夜精品久久av蜜臀| 中文字幕无码久久人妻| 亚洲国产一成久久精品国产成人综合 | 久久这里都是精品| 久久综合久久伊人| 亚洲AV伊人久久青青草原| 日韩电影久久久被窝网| 久久精品亚洲乱码伦伦中文| 国产精品VIDEOSSEX久久发布| 91精品国产91久久久久久|