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

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.¢% 閱讀(1202) 評論(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>
            欧美一级日韩一级| 欧美一区二区啪啪| 欧美国产日韩一区二区三区| 亚洲成人资源| 亚洲欧洲在线播放| 欧美日韩直播| 久久电影一区| 久久都是精品| 亚洲精选视频在线| 在线视频一区观看| 国产一区久久| 亚洲第一主播视频| 国产精品video| 久久字幕精品一区| 欧美电影电视剧在线观看| 亚洲小说区图片区| 欧美一区网站| 亚洲精品自在久久| 亚洲欧洲av一区二区| 伊人久久亚洲美女图片| 亚洲破处大片| 国产一区二区三区观看| 亚洲大片在线观看| 国产目拍亚洲精品99久久精品| 久热精品视频| 欧美午夜精品久久久| 久久久久国产精品麻豆ai换脸| 你懂的视频欧美| 午夜久久福利| 欧美成人69av| 久久精品一区二区三区四区| 欧美大成色www永久网站婷| 午夜视频一区二区| 欧美二区不卡| 久久精品国产999大香线蕉| 欧美国产一区二区三区激情无套| 欧美一区二区三区免费视| 欧美高清在线精品一区| 久久免费99精品久久久久久| 欧美精品免费视频| 欧美a级一区| 国产亚洲精品久久飘花| 一区二区三区视频在线| 亚洲人屁股眼子交8| 久久大逼视频| 久久不见久久见免费视频1| 免费成人网www| 久热精品在线| 国产主播一区二区| 亚洲欧美激情诱惑| 亚洲欧美成人网| 欧美日本国产视频| 亚洲国产高清高潮精品美女| 黄色综合网站| 久久国产黑丝| 久久久久国色av免费看影院| 国产精品久久久久天堂| 亚洲精品日日夜夜| 亚洲激情在线| 欧美丰满高潮xxxx喷水动漫| 美女网站久久| 亚洲高清不卡一区| 免费不卡在线观看| 免费看黄裸体一级大秀欧美| 国产真实乱子伦精品视频| 午夜视频久久久久久| 午夜精品成人在线视频| 国产精品麻豆成人av电影艾秋 | 国产日本欧美一区二区三区在线 | 久久亚洲电影| 黄色日韩在线| 久久夜色精品一区| 欧美激情国产日韩| 亚洲精品小视频| 欧美激情国产高清| 99热这里只有精品8| 亚洲无人区一区| 国产精品爽爽爽| 久久成年人视频| 欧美激情一区二区三区高清视频| 亚洲第一伊人| 欧美精品一卡二卡| 亚洲亚洲精品三区日韩精品在线视频| 亚洲欧美偷拍卡通变态| 国产视频久久| 久久综合九色| av不卡免费看| 久久久夜精品| 亚洲免费电影在线| 国产精品久久久久91| 欧美亚洲一级| 亚洲高清网站| 午夜精品99久久免费| 国产一区在线播放| 欧美激情欧美狂野欧美精品| 一区二区三区日韩欧美精品| 久久国产加勒比精品无码| 伊人色综合久久天天| 欧美激情中文不卡| 亚洲欧美电影院| 亚洲高清视频中文字幕| 亚洲先锋成人| 在线播放豆国产99亚洲| 欧美人与性动交cc0o| 亚洲欧美日韩视频一区| 亚洲高清在线播放| 久久久国产亚洲精品| 亚洲人成在线播放网站岛国| 国产精品日韩专区| 欧美顶级少妇做爰| 欧美亚洲一区二区在线| 91久久国产自产拍夜夜嗨| 亚洲欧美综合网| 亚洲精品综合| 在线观看三级视频欧美| 国产精品久久久久久久久搜平片| 久久综合999| 欧美一区二区三区免费观看视频| 最新亚洲视频| 欧美成在线视频| 久久久免费av| 久久av一区二区| 亚洲一级黄色片| 最新亚洲激情| 亚洲福利视频一区| 韩国美女久久| 国产欧美一区二区精品性色| 欧美日韩色综合| 欧美精品一区三区| 你懂的亚洲视频| 麻豆精品网站| 老鸭窝亚洲一区二区三区| 欧美在线精品一区| 先锋影音久久| 性色av一区二区三区| 亚洲视频一区在线观看| 亚洲精品一区在线| 亚洲精品日韩在线| 亚洲国产精品免费| 亚洲国产精品电影在线观看| 另类春色校园亚洲| 美日韩精品视频免费看| 久久久久青草大香线综合精品| 欧美一区二区三区久久精品| 午夜激情综合网| 欧美一区二区免费| 欧美一区二区三区免费在线看 | 亚洲人成网站色ww在线| 亚洲国产精品成人精品| 亚洲国产经典视频| 亚洲人成免费| 日韩视频永久免费| 在线亚洲精品| 亚洲摸下面视频| 久久精品99无色码中文字幕| 久久精品1区| 猛男gaygay欧美视频| 毛片基地黄久久久久久天堂| 麻豆精品视频在线观看| 欧美aⅴ99久久黑人专区| 欧美激情精品久久久| 亚洲日本va午夜在线影院| 亚洲精品欧美极品| 亚洲午夜伦理| 久久精品动漫| 欧美国产精品日韩| 国产精品爱啪在线线免费观看| 国产精品一卡| 黄色一区二区在线| 亚洲欧美日韩人成在线播放| 亚洲中午字幕| 久久亚洲综合色| 欧美精品福利视频| 国产精品综合视频| 在线精品福利| 亚洲女同性videos| 美女免费视频一区| 一区二区三区欧美视频| 久久国产一区二区三区| 欧美电影免费观看高清| 国产精品福利av| 尹人成人综合网| 亚洲小少妇裸体bbw| 久久久综合网站| 99www免费人成精品| 欧美在线资源| 欧美日韩一区免费| 1000精品久久久久久久久| 亚洲一级黄色| 亚洲国产成人在线| 先锋影音网一区二区| 欧美激情一区二区在线| 国产一区在线免费观看| 99精品国产99久久久久久福利| 久久精品视频免费播放| 亚洲乱码国产乱码精品精可以看| 久久精品国产免费| 国产精品久久久久7777婷婷| 91久久综合| 美女精品在线|