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

posts - 94, comments - 250, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

---INLINE HOOK實現(xiàn)NDIS HOOK
前面講述了如何通過獲取NDIS_PROTOCOL_BLOCK來實現(xiàn)NDIS HOOK,這里講述第二種方法,那就是inline hook方法。說起inline hook,也不是什么新鮮玩意,無非是在一個函數(shù)的首部嵌入一個jmp機器指令,在該函數(shù)執(zhí)行有效代碼前就跳到我們的代理函數(shù),在我們的代理函數(shù)里做了必要的處理以后,再跳回原來的函數(shù),接著執(zhí)行原函數(shù)的指令。
既然tcpip.sys是標準的NDIS協(xié)議驅動,那么收包函數(shù)顯然應該是在tcpip.sys內(nèi)部實現(xiàn)的,我們直接找到這兩個收包函數(shù),然后對其inline hook不就可以了嗎?經(jīng)過逆向分析,我找到了這兩個函數(shù),本人安裝了兩個XP系統(tǒng),其中一個導出了這兩個函數(shù),另一個系統(tǒng)卻沒導出,所以我們?nèi)匀恍枰锰卣鞔a搜索這兩個函數(shù),這兩個函數(shù)聲明如下:
NDIS_STATUS
ARPRcv (NDIS_HANDLE BindContext,
NDIS_HANDLE MacContext,
UCHAR* HeadBuffer,
ULONG HeadSize,
UCHAR* Buffer,
ULONG BufferSize,
ULONG PacketSize);
INT
ARPRcvPacket (NDIS_HANDLE BindContext,
PNDIS_PACKET Packet);
搜索這兩個函數(shù)地址的代碼如下:
//以下全局變量保存兩個函數(shù)的地址
void* ARPRcv=NULL;
void* ARPRcvPacket=NULL;
void SearchProtocolRoutine()
{
//以下分別為兩個收包函數(shù)的特征碼
UCHAR ARPRcvBytes[] ={0x8b,0xff,0x55,0x8b,0xec,0x56,0x8b,0x75,0x08,0x33};
UCHAR ARPRcvPacketBytes[]={0x8b,0xff,0x55,0x8b,0xec,0x51,0x53,0x56,0x57,0x8b};
//獲取tcpip.sys模塊的基地址,該函數(shù)在前一節(jié)已經(jīng)提供給大家
char* base=FindModule("tcpip.sys");
while(ARPRcv==NULL||ARPRcvPacket==NULL)
{
if(ARPRcv==NULL&&
RtlCompareMemory(ARPRcvBytes,base,10)==10)
{
ARPRcv=base;
}
else if(ARPRcvPacket==NULL&&
RtlCompareMemory(ARPRcvPacketBytes,base,10)==10)
{
ARPRcvPacket=base;
}
base++;
}
}
各種編譯器所編譯的函數(shù),前幾個指令都是幾乎一樣的,用來建立堆棧幀,這些指令叫函數(shù)的序言。
在win2000上是三字節(jié)
push ebp
mov ebp, esp
到了winxp以及后續(xù)系統(tǒng)上,則變成了五字節(jié)
mov edi, edi
push ebp
mov ebp, esp
而一個近跳轉指令剛好是五字節(jié),在xp上剛好覆蓋了函數(shù)的序言,所以在XP上掛鉤也相對容易一點,這里著重說明如何對ARPRcv進行掛鉤,我們在ARPRcv內(nèi)部插入一個jmp指令,將跳到ARPRcvProx函數(shù),該函數(shù)是個裸函數(shù),函數(shù)實現(xiàn)如下:
_declspec(naked) ARPRcvProx()//跳板函數(shù)
{
_asm
{
mov edi, edi
push ebp
mov ebp ,esp
//七個參數(shù)開始壓棧
push [ebp+20h]
push [ebp+1ch]
push [ebp+18h]
push [ebp+14h]
push [ebp+10h]
push [ebp+0ch]
push [ebp+8]
call NewARPRcv //調(diào)用NewARPRcv函數(shù)
cmp eax,0x10003 //判斷函數(shù)返回值是否NDIS_STATUS_NOT_ACCEPTED
jz end //如果是NDIS_STATUS_NOT_ACCEPTED,直接結束本函數(shù)
//而不跳回到ARPRcv函數(shù)
mov eax,ARPRcv //如果返回的不是NDIS_STATUS_NOT_ACCEPTED,將會
//執(zhí)行到這條指令,該指令將 ARPRcv函數(shù)的地址裝入eax
add eax,5 //將ARPRcv地址值加上5,存入eax,表示即將跳轉的//地址
jmp eax //開始跳回ARPRcv體內(nèi)
end:
pop ebp
retn 1ch
}
}
在該函數(shù)內(nèi)部,又調(diào)用了NewARPRcv函數(shù),原型和ARPRcv保持一致,也必須由我們自己實現(xiàn):
NDIS_STATUS
NewARPRcv(
IN NDIS_HANDLE ProtocolBindingContext,
IN NDIS_HANDLE MacReceiveContext,
IN PVOID HeaderBuffer,
IN UINT HeaderBufferSize,
IN PVOID LookAheadBuffer,
IN UINT LookaheadBufferSize,
IN UINT PacketSize
)
{
/*
在這里加入你的判斷邏輯代碼,是否攔截該數(shù)據(jù)
如果要攔截,則返回 NDIS_STATUS_NOT_ACCEPTED
否則返回NDIS_STATUS_SUCCESS,把數(shù)據(jù)交給ARPRcv處理
*/
return NDIS_STATUS_SUCCESS;
}
同樣的原理,我們在ARPRcvPacket里面插入jmp指令,將跳轉到ARPRcvPacketProx裸函數(shù),該函數(shù)實現(xiàn)如下:
_declspec(naked) ARPRcvPacketProx()
{
_asm
{
mov edi, edi
push ebp
mov ebp ,esp
//兩個參數(shù)開始壓棧
push [ebp+0ch]
push [ebp+8]
call NewARPRcvPacket//調(diào)用NewARPRcvPacket
cmp eax,0 //如果返回0則表示拒絕該數(shù)據(jù)包
jz end //直接返回本函數(shù)
mov eax ,ARPRcvPacket
add eax ,5
jmp eax //跳回ARPRcvPacket函數(shù)第六個字節(jié)
end: pop ebp
retn 8
}
}
在該函數(shù)內(nèi)部,將會調(diào)用NewARPRcvPacket,函數(shù)實現(xiàn)如下:
INT
NewARPRcvPacket(NDIS_HANDLE BindContext,
PNDIS_PACKET ndisPacket)
{
/*
在這里加入你的判斷邏輯,是否攔截該數(shù)據(jù),如果要攔截,則返回0,
否則返回非0
*/
DbgPrint("RcvPacket");
return 1;
}
請仔細閱讀以上代碼的注釋,接下來,我們還必須提供一個函數(shù)實現(xiàn)安裝和卸載掛鉤功能
void PatchARPRcv(BOOLEAN isPatch)//isPatch為TRUE表示安裝掛鉤,為FALSE表示卸載掛鉤。
{
/*即將用以下五個字節(jié)覆蓋ARPRcv函數(shù)前五個字節(jié)
這5個字節(jié)就是jmp XXXX指令的機器碼,因為跳轉的相對地址還需要
進一步計算,所以暫時用零填充
*/
UCHAR patchBytes[5]={0xe9,0x00,0x00,0x00,0x00};
//即將用以下五個字節(jié)覆蓋ARPRcvPacket函數(shù)前五個字節(jié)
UCHAR patchBytes2[5]={0xe9,0x00,0x00,0x00,0x00};
//保存原始函數(shù)的前五個字節(jié),方便以后恢復掛鉤
UCHAR restoreBytes[5]={0x8b,0xff,0x55,0x8b,0xec};
/*
以下兩行代碼計算跳轉的偏移量
*/
int offset=(char*)ARPRcvProx-(char*)ARPRcv-5;
int offset2=(char*)ARPRcvPacketProx-(char*)ARPRcvPacket-5;
//修正patchBytes和patchBytes2中的相對地址
memcpy(patchBytes+1,&offset,4);
memcpy(patchBytes2+1,&offset2,4);
if(isPatch)
{
DisableWriteProtect();//禁止寫保護
memcpy(ARPRcv,patchBytes,5);
memcpy(ARPRcvPacket,patchBytes2,5);
EnableWriteProtect(); //開啟寫保護
}
else
{
DisableWriteProtect();
memcpy(ARPRcv,restoreBytes,5);
memcpy(ARPRcvPacket,restoreBytes,5);
EnableWriteProtect();
}
}
因為ARPRcv和ARPRcvPacket函數(shù)處于只讀頁,所以必須先禁用寫保護才能向其中插入代碼,禁用寫保護和開啟寫保護代碼如下:
void
DisableWriteProtect()
{
_asm{
cli
mov eax, cr0
and eax, 0FFFEFFFFh
mov cr0, eax
}
}
void
EnableWriteProtect()
{
_asm{
mov eax, cr0
or eax, not 0FFFEFFFFh
mov cr0, eax
sti
}
}
注意這些代碼暫時只適用XP系統(tǒng),在win2000和win2003上都需要少許改動。


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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| 亚洲小视频在线| 日韩视频在线播放| 亚洲婷婷综合久久一本伊一区| 一区二区三区久久精品| 一区二区三区 在线观看视| 一区二区免费在线播放| 性伦欧美刺激片在线观看| 久久激情五月丁香伊人| 久久综合九色综合欧美狠狠| 麻豆精品一区二区综合av| 免费人成精品欧美精品| 亚洲国产小视频| 亚洲综合色在线| 久久精品夜色噜噜亚洲aⅴ| 久久全球大尺度高清视频| 欧美国产精品劲爆| 国产精品电影观看| 在线观看欧美成人| 99在线热播精品免费| 久久aⅴ乱码一区二区三区| 欧美ed2k| 亚洲欧美综合精品久久成人 | 亚洲高清视频在线| 中文精品视频| 久久婷婷久久| 欧美性天天影院| 国产精品99久久久久久白浆小说| 亚洲欧美偷拍卡通变态| 女女同性精品视频| 国产欧美日韩亚洲| 亚洲欧洲精品一区二区三区不卡 | 亚洲第一天堂无码专区| 在线视频免费在线观看一区二区| 欧美一区三区三区高中清蜜桃| 欧美电影免费观看高清完整版| 一本久久综合亚洲鲁鲁| 久久综合给合| 国产综合久久久久久鬼色| 亚洲伊人第一页| 亚洲国产婷婷综合在线精品 | 亚洲国产高清高潮精品美女| 亚洲淫片在线视频| 欧美精品久久天天躁 | 亚洲欧美日韩在线不卡| 欧美成人一区在线| 久久精品人人| 国产精品毛片| 亚洲永久精品国产| 亚洲精品女人| 久久爱91午夜羞羞| 国产欧美日韩视频一区二区三区| av72成人在线| 亚洲精品乱码久久久久久久久| 久久久亚洲欧洲日产国码αv| 亚洲天堂免费观看| 欧美午夜一区二区| 亚洲一区尤物| 一本久久a久久免费精品不卡| 欧美区亚洲区| 亚洲夜晚福利在线观看| 日韩亚洲欧美成人| 欧美日韩高清在线一区| av不卡在线| 亚洲日产国产精品| 欧美色欧美亚洲高清在线视频| 这里只有视频精品| aa成人免费视频| 国产精品午夜在线| 久久精品国产第一区二区三区最新章节| 亚洲视频网站在线观看| 国产精品久久久久国产精品日日| 亚洲影视在线| 午夜精品久久久久久久久 | 亚洲欧美日韩国产综合| 亚洲午夜久久久| 国产精品入口福利| 久久久久国色av免费观看性色| 久久久www免费人成黑人精品| 亚洲国产高清视频| 亚洲伦理在线观看| 国产精品一区在线播放| 久久久亚洲国产美女国产盗摄| 久久成人亚洲| 亚洲精品综合久久中文字幕| av成人免费在线| 国产丝袜一区二区| 亚洲第一伊人| 性久久久久久| 在线电影欧美日韩一区二区私密| 欧美成人按摩| 欧美午夜不卡在线观看免费 | 亚洲午夜在线观看| 亚洲欧美久久久久一区二区三区| 狠狠色丁香婷婷综合| 亚洲国产专区校园欧美| 国产精品视频网站| 欧美成人在线网站| 欧美少妇一区| 欧美mv日韩mv亚洲| 国产精品国产精品国产专区不蜜| 久久不射中文字幕| 欧美精品日韩综合在线| 久久精品女人的天堂av| 蜜桃av久久久亚洲精品| 欧美一级电影久久| 欧美精品一区三区| 麻豆精品在线播放| 国产欧美欧洲在线观看| 亚洲人成啪啪网站| 黄色日韩在线| 亚洲一区二区三区在线| 亚洲黄色一区| 久久久不卡网国产精品一区| 午夜精品久久久久99热蜜桃导演| 美女网站久久| 久久国产欧美日韩精品| 欧美性猛交xxxx乱大交退制版| 久久综合狠狠| 国产亚洲午夜高清国产拍精品| 一区二区三区导航| 亚洲日本一区二区三区| 久久久水蜜桃av免费网站| 亚洲欧美综合v| 欧美日韩在线亚洲一区蜜芽| 亚洲电影第三页| 1769国内精品视频在线播放| 欧美影院在线| 欧美在线不卡| 国产伦精品一区二区三区| 亚洲视频1区| 亚洲在线国产日韩欧美| 国产精品成人播放| 99国产精品99久久久久久| 亚洲精品影院| 欧美精品一区二区三区一线天视频 | 亚洲欧洲精品一区| 久久精彩视频| 久久久久国产精品厨房| 国产欧美精品| 午夜精品久久久久久久久久久久| 午夜精品剧场| 国产伦精品一区二区三区| 香蕉久久夜色精品国产使用方法 | 欧美国产丝袜视频| 亚洲国产精品999| 亚洲另类一区二区| 欧美精品一区二区三区很污很色的 | 另类成人小视频在线| 美日韩在线观看| 亚洲电影观看| 欧美黑人多人双交| 一区电影在线观看| 久久精品免费播放| 激情成人av| 欧美二区不卡| 亚洲小说区图片区| 久久久精品免费视频| **欧美日韩vr在线| 欧美激情精品久久久久久| 欧美国产乱视频| 日韩亚洲欧美成人| 国产精品视频导航| 欧美一区二区三区视频| 欧美电影免费网站| 香蕉久久夜色精品国产使用方法| 国产伦理一区| 久久综合国产精品台湾中文娱乐网| 亚洲人久久久| 久久久精品一区二区三区| 亚洲国产婷婷| 国产欧美日韩三级| 欧美黄色小视频| 欧美一区二区高清在线观看| 亚洲黑丝在线| 久久国产精品99久久久久久老狼| 亚洲激情影视| 国产一级一区二区| 欧美日韩亚洲一区三区| 久久青草欧美一区二区三区| 在线性视频日韩欧美| 欧美电影免费观看高清| 欧美专区亚洲专区| 中文无字幕一区二区三区| 极品少妇一区二区三区| 欧美午夜视频| 欧美大片免费观看| 久久久久久久久蜜桃| 亚洲尤物在线| 亚洲精品字幕| 欧美不卡高清| 欧美专区第一页| 亚洲欧美日韩国产中文| aa亚洲婷婷| 一本色道久久综合亚洲91| 亚洲国产精品第一区二区三区| 国产午夜精品久久| 国产精品国产三级国产普通话三级|