青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

S.l.e!ep.¢%

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

利用WH_DEBUG消息進行反HOOK

Posted on 2010-01-10 16:48 S.l.e!ep.¢% 閱讀(1200) 評論(2)  編輯 收藏 引用 所屬分類: RootKit
【原創】利用WH_DEBUG消息進行反HOOK
ningkai 當前離線

標 題: 【原創】利用WH_DEBUG消息進行反HOOK
作 者: ningkai
時 間: 2007-10-09,19:14
鏈 接: http://bbs.pediy.com/showthread.php?t=53016

以前在學習鉤子的時候對于WH_DEBUG這個類型很是不解釋,不知道它是做什么用的,在網上找了一找,發現也沒有什么有價值的文章。在逆向分析“熱血江湖”突然發現WH_DEBUG竟被用來進行反鍵盤記錄(這是老版本,現在的版本已經用了最新的技術,原理沒弄明白,哪位要是弄明白了,希望可以指點一下)。仔細研究了一下,弄明白了其中的原理,現在就介紹給一下。
首先要將WH_DEBUG介紹一下。WH_DEBUG為調試鉤子,用來給鉤子函數除錯。在系統調用系統中與其他Hook關聯的Hook鉤子例程之前,系統會調用WH_DEBUG?Hook鉤子例程。你可以使用這個Hook來決定是否允許系統調用與其他Hook關聯的Hook鉤子例程。WH_DEBUG調用DebugProc鉤子例程。
DebugProc語法:
LRESULT?CALLBACK?DebugProc(
??int?nCode,
????WPARAM?wParam,
????LPARAM?lParam
)
nCode傳遞到鉤子例程的鉤子代碼。
wParam指示當前即將被調用的鉤子的類型,如WH_MOUSE,WH_KEYBOARD?參數。
lParam?指向DEBUGHOOKINFO?結構。
typedef?struct?
{
????DWORD?idThread;
????DWORD?idThreadInstaller;
????LPARAM?lParam;
????WPARAM?wParam;
????int?code;
}?DEBUGHOOKINFO,?*PDEBUGHOOKINFO;
idThread?安裝WH_DEBUG鉤子的線程ID。
idThreadInstaller?當前即將被調用的鉤子所在的線程ID。
lParam?當前即將被調用的鉤子的lParam參數。
wParam?當前即將被調用的鉤子的wParam參數。
Code?當前即將被調用的鉤子的nCode參數。

返回值:當你已經處理了該鉤子并且不希望即將被調用的鉤子繼續執行,則必須返回非0值?否則請返回CallNextHookEx的值。

進行反HOOK時只要知道判斷idThread和idThreadInstaller是否相等就可了。如果相等,說明即將被調用的鉤子是自己線程中鉤子;如果不等,說明是其它線程中的鉤子,只要返回非0值就可以了,這時即將被調用的鉤子就不會執行了。
程序編寫:
新建DLL工程,寫入以下代碼,然后調用InstallHook()安裝WH_DEBUG鉤子,調用UnInstallHook()卸載WH_DEBUG鉤子。
#ifndef?MYLIBAPI
#define?MYLIBAPI?extern?"C"?__declspec(dllimport)
#endif

HHOOK?DEBUG_hhook;
HINSTANCE?handle;

MYLIBAPI?bool?WINAPI?InstallHook();
MYLIBAPI?bool?WINAPI?UnInstallHook();

LRESULT?CALLBACK?DebugProc(int?nCode,?WPARAM?wParam,?LPARAM?lParam)?//WH_DEBUG鉤子例程
{
??DEBUGHOOKINFO?*debug=(DEBUGHOOKINFO?*)lParam;
//如果要編寫反鍵盤記錄代碼,可以改成
//?if(debug->idThread!=debug->idThreadInstaller?&&?wParam==?WH_KEYBOARD)
//{
//?return?1;
//}
??if(debug->idThread!=debug->idThreadInstaller)???//是否相等,如果不等則不執行
??{
????return?1;
??}
??return?::CallNextHookEx(DEBUG_hhook,?nCode,?wParam?,lParam);
}

BOOL?APIENTRY?DllMain(?HINSTANCE?hModule,?
???????????????????????DWORD??ul_reason_for_call,?
???????????????????????LPVOID?lpReserved
???????????)
{
??handle=hModule;
????return?TRUE;
}

bool?WINAPI?InstallHook()??//安裝WH_DEBUG鉤子
{
DEBUG_hhook=::SetWindowsHookEx(WH_DEBUG,(HOOKPROC)DebugProc,handle,?NULL);
If(DEBUG_hhook==NULL)
Return?false;
??return?true;
}

bool?WINAPI?UnInstallHook()//卸載WH_DEBUG鉤子
{
??UnhookWindowsHookEx(DEBUG_hhook);
??return?true;
}
當然,破解這種方法的辦法也很簡單。比如你要用HOOK進行鍵盤攔截時,在安裝WH_KEYBOARD時,同時安裝一個WH_DEBUG鉤子。這時你自己的WH_DEBUG鉤子將攔截到你自己的WH_KEYBOARD,DEBUGHOOKINFO?結構中的lParam存放的是WH_KEYBOARD的lParam,wParam存放的是WH_KEYBOARD的wParam,只要在這里處理WH_KEYBOARD就可以了。因為HOOK鏈是按照后進先出的順序執行的,所以你只要在反HOOK的WH_DEBUG之后安裝WH_DEBUG,就可以在它之前進行處理了。
我只用這種方法進行過反鍵盤和鼠標,其它的鉤子,我還沒有試過,如果有什么不對的地方,還請大家指點!!!

????很久以前寫的文章,一直沒發布,突然想起來了,發出來共大家參考,本來是有源碼的,可是權限不夠,不能發附件,所以請大家海涵

Feedback

# re: 利用WH_DEBUG消息進行反HOOK   回復  更多評論   

2010-02-23 16:50 by Pencil.C++
debug->idThread!=debug->idThreadInstaller

這個等式永遠成立,在2000/xp之后的系統中。因為idThreadInstaller始終是0

# re: 利用WH_DEBUG消息進行反HOOK   回復  更多評論   

2010-02-23 20:24 by S.l.e!ep.¢%
那2K/XP 后沒法判斷?
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲国产精品一区在线观看不卡| av成人免费| 亚洲少妇在线| 国产乱子伦一区二区三区国色天香 | 亚洲国产精品一区在线观看不卡 | 国产日产欧产精品推荐色| 免费亚洲视频| 亚洲先锋成人| 亚洲欧美一区二区三区在线| 激情综合网激情| 日韩亚洲精品电影| 一区二区精品在线观看| 国产亚洲激情| 99re6热只有精品免费观看| 国产一区二区精品丝袜| 亚洲国产精品美女| 国产农村妇女毛片精品久久莱园子| 久久另类ts人妖一区二区| 欧美日韩aaaaa| 女人香蕉久久**毛片精品| 国产精品理论片| 91久久线看在观草草青青| 国内一区二区在线视频观看| 亚洲免费观看| 亚洲精品在线免费| 欧美aa国产视频| 欧美激情日韩| 亚洲黄一区二区| 久热国产精品视频| 免费成人在线观看视频| 国产精品私人影院| 亚洲小少妇裸体bbw| 亚洲欧美日本日韩| 国产精品亚发布| 久久久99国产精品免费| 麻豆国产精品777777在线| 国产女人水真多18毛片18精品视频| 夜夜精品视频| 久久先锋影音| 午夜精品三级视频福利| 免费久久久一本精品久久区| 亚洲精选在线观看| 欧美系列精品| 性欧美1819性猛交| 国产一区在线看| 欧美成年人在线观看| 日韩视频一区二区在线观看| 欧美影片第一页| 亚洲第一精品夜夜躁人人爽 | 影音先锋成人资源站| 免费成人高清视频| 这里只有精品丝袜| 免费不卡在线观看| 久久xxxx| 亚洲制服av| 日韩视频免费看| 国产一区二区电影在线观看| 欧美精品一区二区视频| 亚洲一区视频在线| 亚洲国产裸拍裸体视频在线观看乱了| 亚洲欧洲av一区二区三区久久| 在线观看欧美一区| 狠狠色丁香婷婷综合| 国产精品白丝jk黑袜喷水| 久久人人看视频| 欧美一区二区视频97| 亚洲一区二区三区视频播放| 亚洲激情在线视频| 亚洲国产精品一区二区第一页 | 国产农村妇女毛片精品久久麻豆 | 一区二区欧美国产| 1024国产精品| 久久精品视频一| 欧美在线观看网址综合| 欧美一级精品大片| 久久丁香综合五月国产三级网站| 在线中文字幕一区| 中文高清一区| 久久久免费av| 欧美成人免费在线| 欧美成人激情在线| 欧美激情一区二区三区在线视频观看 | 国产一区二区三区丝袜| 狠狠色狠狠色综合日日91app| 韩日精品在线| 亚洲精品一区二区三区四区高清 | 久久人人九九| 亚洲国产精品久久91精品| 亚洲精选91| 亚洲一区免费观看| 麻豆成人综合网| 国产精品私拍pans大尺度在线| 国产美女诱惑一区二区| 亚洲国产免费| 久久久精品999| 亚洲精品欧美极品| 久久精品国产欧美亚洲人人爽| 欧美顶级艳妇交换群宴| 国产一区二区三区最好精华液| 一区二区三区欧美在线观看| 久久久久欧美| 亚洲欧美激情视频| 欧美日韩你懂的| 亚洲另类在线一区| 欧美大片一区二区三区| 欧美在线在线| 黑丝一区二区三区| 久久国产精彩视频| …久久精品99久久香蕉国产| 亚洲一区二区三区免费在线观看| 欧美福利精品| 欧美电影专区| 国产欧美在线看| 亚洲欧美日韩国产一区二区三区 | 亚洲茄子视频| 欧美另类高清视频在线| 亚洲作爱视频| 一区二区免费在线播放| 国产精品久久福利| 亚洲午夜激情网站| 亚洲视频国产视频| 国产欧美一区二区精品忘忧草| 欧美一区三区二区在线观看| 午夜视频久久久| 伊人激情综合| 亚洲人成亚洲人成在线观看| 欧美日韩精品综合在线| 宅男噜噜噜66一区二区| 亚洲免费伊人电影在线观看av| 嫩草国产精品入口| 久久久久久一区二区| 亚洲人久久久| 亚洲欧美日韩另类| 激情综合五月天| 日韩视频中文| 激情综合视频| 亚洲欧美日韩成人| 亚洲激情啪啪| 亚洲欧美国产毛片在线| 亚洲精品美女在线观看| 亚洲天堂av在线免费观看| 亚洲自啪免费| 中文久久乱码一区二区| 欧美在线日韩在线| 亚洲欧美日本视频在线观看| 欧美在线观看视频一区二区三区 | 亚洲视频在线一区| 美女视频黄a大片欧美| 国产精品v欧美精品v日韩精品| 免费精品视频| 国内视频一区| 久久国产精品久久精品国产 | 久久精品中文| 久久国产精品99久久久久久老狼| 欧美三级乱人伦电影| 亚洲国产欧美久久| 亚洲人成7777| 欧美日韩国产影片| 日韩午夜在线| 亚洲综合久久久久| 国产精品女主播在线观看| 亚洲天堂成人在线视频| 亚洲欧美精品在线观看| 国产欧美亚洲视频| 久久久久成人精品免费播放动漫| 久久五月激情| 一区二区高清视频在线观看| 欧美日韩视频| 欧美亚洲尤物久久| 亚洲激情电影中文字幕| 一区二区欧美亚洲| 国产亚洲免费的视频看| 另类图片国产| 午夜精品区一区二区三| 男男成人高潮片免费网站| 99精品福利视频| 国产中文一区| 欧美日韩亚洲一区二区| 久久婷婷久久| 午夜在线精品偷拍| 亚洲欧洲久久| 欧美不卡在线| 久久久99精品免费观看不卡| 亚洲精品在线一区二区| 国产资源精品在线观看| 欧美午夜精品理论片a级按摩| 久久蜜臀精品av| 性xx色xx综合久久久xx| 亚洲精品人人| 最新国产乱人伦偷精品免费网站| 久久婷婷综合激情| 欧美在线二区| 久久国产88| 久久精品视频播放| 午夜日韩av| 久久成人18免费网站| 欧美在线观看天堂一区二区三区| 久久先锋资源| 久久久精品免费视频| 亚洲摸下面视频|