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

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

探索NDIS HOOK新的實現方法(2)

Posted on 2008-08-30 23:43 Condor 閱讀(1977) 評論(0)  編輯 收藏 引用

---INLINE HOOK實現NDIS HOOK
前面講述了如何通過獲取NDIS_PROTOCOL_BLOCK來實現NDIS HOOK,這里講述第二種方法,那就是inline hook方法。說起inline hook,也不是什么新鮮玩意,無非是在一個函數的首部嵌入一個jmp機器指令,在該函數執行有效代碼前就跳到我們的代理函數,在我們的代理函數里做了必要的處理以后,再跳回原來的函數,接著執行原函數的指令。
既然tcpip.sys是標準的NDIS協議驅動,那么收包函數顯然應該是在tcpip.sys內部實現的,我們直接找到這兩個收包函數,然后對其inline hook不就可以了嗎?經過逆向分析,我找到了這兩個函數,本人安裝了兩個XP系統,其中一個導出了這兩個函數,另一個系統卻沒導出,所以我們仍然需要用特征碼搜索這兩個函數,這兩個函數聲明如下:
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);
搜索這兩個函數地址的代碼如下:
//以下全局變量保存兩個函數的地址
void* ARPRcv=NULL;
void* ARPRcvPacket=NULL;
void SearchProtocolRoutine()
{
//以下分別為兩個收包函數的特征碼
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模塊的基地址,該函數在前一節已經提供給大家
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++;
}
}
各種編譯器所編譯的函數,前幾個指令都是幾乎一樣的,用來建立堆棧幀,這些指令叫函數的序言。
在win2000上是三字節
push ebp
mov ebp, esp
到了winxp以及后續系統上,則變成了五字節
mov edi, edi
push ebp
mov ebp, esp
而一個近跳轉指令剛好是五字節,在xp上剛好覆蓋了函數的序言,所以在XP上掛鉤也相對容易一點,這里著重說明如何對ARPRcv進行掛鉤,我們在ARPRcv內部插入一個jmp指令,將跳到ARPRcvProx函數,該函數是個裸函數,函數實現如下:
_declspec(naked) ARPRcvProx()//跳板函數
{
_asm
{
mov edi, edi
push ebp
mov ebp ,esp
//七個參數開始壓棧
push [ebp+20h]
push [ebp+1ch]
push [ebp+18h]
push [ebp+14h]
push [ebp+10h]
push [ebp+0ch]
push [ebp+8]
call NewARPRcv //調用NewARPRcv函數
cmp eax,0x10003 //判斷函數返回值是否NDIS_STATUS_NOT_ACCEPTED
jz end //如果是NDIS_STATUS_NOT_ACCEPTED,直接結束本函數
//而不跳回到ARPRcv函數
mov eax,ARPRcv //如果返回的不是NDIS_STATUS_NOT_ACCEPTED,將會
//執行到這條指令,該指令將 ARPRcv函數的地址裝入eax
add eax,5 //將ARPRcv地址值加上5,存入eax,表示即將跳轉的//地址
jmp eax //開始跳回ARPRcv體內
end:
pop ebp
retn 1ch
}
}
在該函數內部,又調用了NewARPRcv函數,原型和ARPRcv保持一致,也必須由我們自己實現:
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
)
{
/*
在這里加入你的判斷邏輯代碼,是否攔截該數據
如果要攔截,則返回 NDIS_STATUS_NOT_ACCEPTED
否則返回NDIS_STATUS_SUCCESS,把數據交給ARPRcv處理
*/
return NDIS_STATUS_SUCCESS;
}
同樣的原理,我們在ARPRcvPacket里面插入jmp指令,將跳轉到ARPRcvPacketProx裸函數,該函數實現如下:
_declspec(naked) ARPRcvPacketProx()
{
_asm
{
mov edi, edi
push ebp
mov ebp ,esp
//兩個參數開始壓棧
push [ebp+0ch]
push [ebp+8]
call NewARPRcvPacket//調用NewARPRcvPacket
cmp eax,0 //如果返回0則表示拒絕該數據包
jz end //直接返回本函數
mov eax ,ARPRcvPacket
add eax ,5
jmp eax //跳回ARPRcvPacket函數第六個字節
end: pop ebp
retn 8
}
}
在該函數內部,將會調用NewARPRcvPacket,函數實現如下:
INT
NewARPRcvPacket(NDIS_HANDLE BindContext,
PNDIS_PACKET ndisPacket)
{
/*
在這里加入你的判斷邏輯,是否攔截該數據,如果要攔截,則返回0,
否則返回非0
*/
DbgPrint("RcvPacket");
return 1;
}
請仔細閱讀以上代碼的注釋,接下來,我們還必須提供一個函數實現安裝和卸載掛鉤功能
void PatchARPRcv(BOOLEAN isPatch)//isPatch為TRUE表示安裝掛鉤,為FALSE表示卸載掛鉤。
{
/*即將用以下五個字節覆蓋ARPRcv函數前五個字節
這5個字節就是jmp XXXX指令的機器碼,因為跳轉的相對地址還需要
進一步計算,所以暫時用零填充
*/
UCHAR patchBytes[5]={0xe9,0x00,0x00,0x00,0x00};
//即將用以下五個字節覆蓋ARPRcvPacket函數前五個字節
UCHAR patchBytes2[5]={0xe9,0x00,0x00,0x00,0x00};
//保存原始函數的前五個字節,方便以后恢復掛鉤
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函數處于只讀頁,所以必須先禁用寫保護才能向其中插入代碼,禁用寫保護和開啟寫保護代碼如下:
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系統,在win2000和win2003上都需要少許改動。


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   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>
            欧美成年人在线观看| 亚洲一区3d动漫同人无遮挡| 一本久久综合亚洲鲁鲁五月天| 久久久久久久久伊人| 亚洲一卡久久| 欧美午夜理伦三级在线观看| 99精品视频免费在线观看| 久久免费视频一区| 香蕉成人啪国产精品视频综合网| 欧美视频一区二区三区…| 亚洲精品综合| 99xxxx成人网| 国产精品xvideos88| 亚洲新中文字幕| 99视频国产精品免费观看| 欧美日韩不卡一区| 亚洲午夜精品一区二区| 亚洲性夜色噜噜噜7777| 国产精品视频成人| 久久国产精品久久久久久电车| 欧美一区1区三区3区公司| 国产在线精品自拍| 欧美成人综合网站| 欧美电影在线观看| 99re6热只有精品免费观看| 99这里有精品| 国产视频久久久久| 免费在线播放第一区高清av| 欧美1区视频| 亚洲一二区在线| 亚洲免费一级电影| 亚洲国产高清视频| 一本大道久久精品懂色aⅴ| 国产日韩欧美亚洲| 欧美成熟视频| 国产欧美日韩视频一区二区| 欧美在线精品免播放器视频| 久久国产视频网站| 一本色道久久精品| 亚洲欧美福利一区二区| 亚洲国产精品久久人人爱蜜臀| 亚洲另类视频| 国产一区二区三区久久 | 99亚洲伊人久久精品影院红桃| 国产精品99免视看9| 久久aⅴ国产欧美74aaa| 久久亚洲精品欧美| 亚洲性视频h| 久久精品综合网| 亚洲香蕉在线观看| 麻豆精品视频在线| 亚洲欧美日韩成人高清在线一区| 久久久天天操| 欧美一区午夜视频在线观看| 麻豆精品网站| 久久精品视频在线看| 欧美精品在线看| 噜噜噜在线观看免费视频日韩| 欧美激情aⅴ一区二区三区| 久久手机免费观看| 国产日韩欧美亚洲| 性欧美精品高清| 欧美中日韩免费视频| 国产精品一级在线| 亚洲无线一线二线三线区别av| 9色国产精品| 欧美激情视频给我| 亚洲欧洲精品一区二区三区波多野1战4| 国产综合久久| 久久精品日产第一区二区三区| 久久九九全国免费精品观看| 国产日韩欧美亚洲| 久久国产欧美| 欧美黑人在线播放| 亚洲欧洲一区二区三区| 欧美国产日韩免费| 亚洲肉体裸体xxxx137| 在线一区二区三区四区五区| 欧美区在线播放| 99视频精品免费观看| 亚洲一区二区在线免费观看视频 | 免费视频最近日韩| 亚洲国产婷婷香蕉久久久久久| 亚洲福利在线观看| 欧美激情一区二区三区在线| 亚洲精品美女在线| 亚洲欧美另类国产| 国产一区二区中文字幕免费看| 久久久99国产精品免费| 欧美激情区在线播放| 亚洲看片网站| 国产精品久久久久av| 欧美伊人久久久久久久久影院 | 久久精品欧美| 亚洲国产精品视频| 欧美视频一区二区三区| 久久大香伊蕉在人线观看热2| 免费观看成人www动漫视频| 亚洲日本一区二区三区| 国产精品v欧美精品v日本精品动漫 | 亚洲国产日韩欧美综合久久| 欧美精品在线观看播放| 性欧美8khd高清极品| 欧美大片在线看| 香蕉久久精品日日躁夜夜躁| 激情六月婷婷综合| 欧美视频免费在线| 久久激情视频| 亚洲午夜精品福利| 亚洲电影在线免费观看| 亚洲一区三区电影在线观看| 永久91嫩草亚洲精品人人| 欧美午夜一区二区| 免费看的黄色欧美网站| 午夜精品剧场| 一区二区三区日韩欧美精品| 久久一区二区三区国产精品 | 一区二区三区.www| 国内精品久久久久久久影视麻豆 | 欧美日韩福利在线观看| 久久精品91| 亚洲午夜女主播在线直播| 欧美激情亚洲自拍| 久久久久久久久久码影片| 亚洲影视中文字幕| 亚洲人www| 精品成人在线视频| 国产欧美一区二区三区在线看蜜臀 | 99国产一区| 欧美福利视频在线观看| 久久久99爱| 午夜精品www| 亚洲永久精品国产| 亚洲免费观看视频| 亚洲国产人成综合网站| 国内视频精品| 国产一区二区三区精品久久久| 国产精品二区二区三区| 欧美日韩视频在线一区二区观看视频 | 美女日韩在线中文字幕| 久久精彩视频| 欧美一区二区三区精品| 午夜免费在线观看精品视频| 亚洲自拍高清| 亚洲天堂男人| 在线视频一区观看| 99视频精品在线| 一区二区三区你懂的| 99精品久久久| 一区电影在线观看| 中文在线资源观看网站视频免费不卡 | 亚洲第一搞黄网站| 在线色欧美三级视频| 狠狠色丁香久久婷婷综合_中| 国产夜色精品一区二区av| 国产色综合网| 在线日韩av永久免费观看| 精品成人一区二区三区| 一区在线视频| 亚洲国产精品一区二区第四页av| 亚洲国产精品久久久久婷婷老年| 91久久国产综合久久| 亚洲理伦在线| 亚洲一区二区三区在线| 欧美一区二区三区四区在线观看地址| 香蕉久久a毛片| 麻豆精品国产91久久久久久| 欧美激情一区在线| 一本久道综合久久精品| 亚洲欧美国产高清| 久久久夜色精品亚洲| 欧美日本高清| 国产裸体写真av一区二区| 雨宫琴音一区二区在线| 日韩一二三区视频| 校园春色综合网| 欧美~级网站不卡| 在线视频精品一| 小处雏高清一区二区三区| 美女图片一区二区| 国产精品电影网站| 在线播放日韩专区| 亚洲一区中文| 久久亚洲一区| 一本久道久久久| 久久久精品视频成人| 欧美黄免费看| 国产亚洲激情视频在线| 99re热这里只有精品视频| 久久成人一区| 99精品欧美| 久久夜色精品国产欧美乱极品 | 蜜臀久久久99精品久久久久久| 国产精品mv在线观看| 在线免费一区三区| 久久国产精品99精品国产| 99精品欧美一区二区三区综合在线 | 免费成人黄色| 亚洲制服丝袜在线| 欧美日本亚洲|