• <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>

            Hook導入表 —— 實現掛鉤FreeLibaray和HOOK延遲加載模塊的API

              最近在研究Windows Ring3上的API Hook,對HOOK導入表這種方法進行了研究。HOOK導入表所用的C++類大同小異,不同的就是如何實現HOOK一個延遲加載的模塊中的函數,以及FreeLibaray某個函數之后再次LoadLibaray加載這個模塊所導致的模塊基地址不同的時候,這時該如何HOOK住這個模塊中的API。
              顯然地,掛鉤LoadLibarayA/W、LoadLibarayExA/W、GetProcAddress這些函數還不夠,還需要掛鉤FreeLibrary函數。這里我參考了《Windows核心編程》(第五版)中的一個程序,封裝了一個C++類,能夠HOOK住FreeLibrary,同時也能解決延遲加載的問題。
              以下是這個類的聲明:

            CApiHook類聲明

             

              想必其中某些函數不需要說了,需要說明的是FreeLibaray_Hook函數,這個函數是FreeLibaray的替換函數,通過sm_FreeLibrary對象進行HOOK。
              開始寫這個函數的時候,遇到了困難,理由是這樣的,因為如果這段代碼作為DLL注入到目標進程中去,如果通過鉤子的方法注入到目標進程中時,那么卸載鉤子時,會引發目標進程調用FreeLibaray來釋放這個DLL,此時會調用FreeLibaray_Hook函數,哪怕在這個函數的最后“return ::FreeLibaray(hLibModule)”,也會出現問題。因為這個函數會產生了C/C++運行時的框架代碼,就會在返回之后調用一些框架代碼,比如調用C++類的析構函數之類,而此時該模塊已經從目標進程中卸載,這必然會導致內存訪問違規。因此,必須如下定義該函數:

            __declspec(naked) BOOL WINAPI CApiHook::FreeLibrary_Hook(HMODULE hLibModule)

              這樣,VC編譯器就不會對CApiHook::FreeLibaray_Hook函數產生一些框架代碼,就需要自己寫內聯匯編來維持堆棧的平衡。這里給出這個函數的定義:
            CApiHook::FreeLibrary_Hook

              這里給出CApiHook類的完整定義:

             

            CApiHook類和一些輔助函數的定義

             

              如上就可以實現掛鉤FreeLibaray函數的功能了。

              同時,這里在HOOK所有LoadLibaray*函數的時候,調用了FexupNewlyLoadedModule函數,該函數會遍歷所有CApiHook對象,查看是否存在某個對象的API原地址為NULL,如果是,就檢測模塊名是否一致,這樣就可以通過模塊得到這個API原始地址了,這樣就可以解決延遲加載的問題。

            posted on 2009-08-14 13:36 小虎無憂 閱讀(1968) 評論(2)  編輯 收藏 引用 所屬分類: DLL

            評論

            # re: Hook導入表 —— 實現掛鉤FreeLibaray和HOOK延遲加載模塊的API 2009-08-14 16:21 萬連文


            XTP的Skin模塊里面也有API的HOOK,做的也相當不錯  回復  更多評論   

            # re: Hook導入表 —— 實現掛鉤FreeLibaray和HOOK延遲加載模塊的API 2009-08-15 11:36 樂蜂網

            還不錯啊~~  回復  更多評論   

            <2025年8月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            導航

            統計

            常用鏈接

            留言簿

            隨筆分類

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            亚洲国产成人乱码精品女人久久久不卡 | 久久久久亚洲AV无码专区体验| 91精品国产综合久久香蕉| 久久婷婷久久一区二区三区 | 久久精品午夜一区二区福利| 色综合合久久天天综合绕视看| 欧美一级久久久久久久大片| 久久久91精品国产一区二区三区 | 久久亚洲av无码精品浪潮| 狠狠精品久久久无码中文字幕| 色婷婷狠狠久久综合五月| 狠狠精品干练久久久无码中文字幕 | 亚洲精品国产第一综合99久久| 合区精品久久久中文字幕一区| 精品久久久无码21p发布| 久久久婷婷五月亚洲97号色| 久久精品国产69国产精品亚洲| 久久er国产精品免费观看8| 亚洲国产成人久久综合一区77 | 久久人人爽人人精品视频| 久久国产免费直播| 欧美日韩中文字幕久久久不卡| 久久精品国产亚洲av水果派| 久久久国产亚洲精品| 久久久久亚洲av成人无码电影| 久久ww精品w免费人成| 久久精品人人做人人爽电影蜜月| 一本色道久久HEZYO无码| 亚洲午夜无码久久久久| 色综合久久无码五十路人妻| 97久久久久人妻精品专区| 久久er热视频在这里精品| 久久丫精品国产亚洲av不卡 | 精品久久亚洲中文无码| 性欧美大战久久久久久久久| 色婷婷综合久久久久中文一区二区 | 中文字幕久久久久人妻| 国产精品毛片久久久久久久| 久久久久久久久久久久中文字幕 | 午夜天堂精品久久久久| 亚洲欧美久久久久9999|