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

S.l.e!ep.¢%

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

HOOK SSDT Hide Process (三)

Posted on 2009-10-25 16:06 S.l.e!ep.¢% 閱讀(496) 評論(0)  編輯 收藏 引用 所屬分類: RootKit
前:HOOK SSDT Hide Process (二)

[新資料] SSDT HIDE Process
[舊資料] HOOK SSDT實現進程隱藏

舊資料中的 Hook 是如此實現的

  1. VOID Hook()
  2. {
  3. ? ? ? ? DbgPrint("Entry Hook()\n");
  4. ? ? ? ? OldAddress =(ULONG)KeServiceDescriptorTable->ServiceTableBase + 4*0xAd;//用windbg反匯編查到zwquerysysteminformationde
  5. ???????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????//的ID號是0xADh
  6. ? ? ? ? DbgPrint("KeServiceDescriptorTable->ServiceTableBase is :0x%0x\n",KeServiceDescriptorTable->ServiceTableBase);
  7. ? ? ? ? //保存原來函數的地址
  8. ? ? ? ? OldZwQuerySystemInformation = (ZWQUERYSYSTEMINFORMATION) *(ULONG *)OldAddress;
  9. ??DbgPrint("OldZwQuerySystemInformation is :0x%0x\n", OldZwQuerySystemInformation);
  10. ??DbgPrint("MyZwQuerySystemInformation is :0x%0x\n", MyZwQuerySystemInformation);
  11. ? ?//取消內存寫保護
  12. ??_asm
  13. ??{
  14. ? ? cli
  15. ???
  16. ? ?? ?mov??eax,cr0??
  17. ? ?? ?and??eax,not 10000h
  18. ? ?? ?mov??cr0,eax
  19. ??????
  20. ??}
  21. ???
  22. ? ? ? ? *(ULONG*)OldAddress =(ULONG) MyZwQuerySystemInformation;? ?? ? //mark? ?MyZwQuerySystemInformation;
  23. ??
  24. ??//還原內存寫保護
  25. ??_asm
  26. ??{??
  27. ??
  28. ? ? mov??eax,cr0
  29. ? ?? ?or? ?eax,10000h
  30. ? ?? ?mov??cr0,eax
  31. ? ?? ?sti
  32. ??
  33. ??
  34. ??}
  35. }

OldAddress =(ULONG)KeServiceDescriptorTable->ServiceTableBase + 4*0xAd;
//用windbg反匯編查到zwquerysysteminformationde的ID號是0xADh
1. zwquerysysteminformationde的ID號是0xADh?? 這個ID是如何得來的?
A: 用 Windbg? u 顯示 zwquerysysteminformation 所在地址都可以看到, 見Q3

Q2. 4表示指針的大小?如果在 64機器上就應該是 8 了?
A:?? 是的,所以正規寫法應該是
#define SYSTEMSERVICE(_function)? KeServiceDescriptorTable.ServiceTableBase[ *(PULONG)((PUCHAR)_function+1)]

Q3. 另一種寫法是
#define SYSTEMSERVICE(_function)? KeServiceDescriptorTable.ServiceTableBase[ *(PULONG)((PUCHAR)_function+1)]
// save old system call locations
OldZwQuerySystemInformation =(ZWQUERYSYSTEMINFORMATION)(SYSTEMSERVICE(ZwQuerySystemInformation));

*(PULONG) 是地址的偏移類型, 相關于 *4, 但 PUCHAR 又是什么? _function+1 又表示什么?
"將_Function+1即可確定ServiceID的位置,即在系統服務調度表中的入口地址"

A:四個有用的宏
SYSTEMSERVICE macro:可以獲得由ntoskrnl.exe導出函數,以Zw*開頭函數的地址,這個函數的返回值就是Nt*函數,Nt*函數的地址就在SSDT中
SYSCALL_INDEX macro:獲得Zw*函數的地址并返回與之通信的函數在SSDT中的索引。
這兩個宏之所以能工作,是因為所有的Zw*函數都開始于opcode:MOV eax, ULONG,這里的ULONG就是系統調用函數在SSDT中的索引。
例:
00401023????? A1 94214000??????? mov???? eax, dword ptr [402194]
A1 表示?? ?mov eax
94214000 表示ULONG
所有 Zw* 開頭的函數最開始的第一條指令是? MOV eax, ULONG, 這里的ULONG就是系統調用函數在SSDT中的索引。
_function 是函數地址, (PUCHAR)_function+1?? 指向 ULONG, 再把它轉成 PULONG? ,就可以拿到 系統調用函數在SSDT中的索引 (Nt*函數的地址)


HOOK_SYSCALL和UNHOOK_SYSCALL macros:獲得Zw*函數的地址,取得他的索引,自動的交換SSDT中索引所對應的函數地址和我們hook函數的地址。
這四個宏具體是:
#define SYSTEMSERVICE(_func)?KeServiceDescriptorTable.ServiceTableBase[ *(PULONG)((PUCHAR)_func+1)]
??
#define SYSCALL_INDEX(_Function) *(PULONG)((PUCHAR)_Function+1)
??
#define HOOK_SYSCALL(_Function, _Hook, _Orig )??\
_Orig = (PVOID) InterlockedExchange( (PLONG)???\
&MappedSystemCallTable[SYSCALL_INDEX(_Function)], (LONG) _Hook)
??
#define UNHOOK_SYSCALL(_Func, _Hook, _Orig )??\
InterlockedExchange((PLONG)?\
&MappedSystemCallTable[SYSCALL_INDEX(_Func)], (LONG) _Hook)

Hook SSDT 其實就是把 SSDT 里面的函數地址替換成自己的處理函數, 一般在 DriverEntry() 就HOOK了
在 DriverUnload() 里再把 SSDT 里面的函數地址還原?

在寫 KeServiceDescriptorTable.ServiceTableBase? 時有一個重要步驟
需要去掉'內存保護'才可以寫入
Q:為何這個變量會受到'內存保護'?? 受'內存保護'的意義是?既然有辦法去掉'內存保護',那為何還要保護呢?

目前所知,去掉'內存保護'有兩種方法
1. 設置 CR0 寄存器的標志位
2. MDL

Q1: 這兩種方法的區別是什么?
Q2: MDL 的原理又是什么?

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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免费| 国产精品黄色在线观看| 国产精品一区二区欧美| 国产亚洲精品久| 亚洲国产精品视频| 一本一本a久久| 亚洲欧美激情精品一区二区| 欧美一区1区三区3区公司| 久久成人在线| 欧美电影打屁股sp| 宅男在线国产精品| 久久久久久久久久久一区 | 一区二区不卡在线视频 午夜欧美不卡在 | 亚洲卡通欧美制服中文| 亚洲午夜精品福利| 久久精品国产99精品国产亚洲性色| 久久米奇亚洲| 国产色产综合产在线视频| 亚洲国产精品一区二区第一页| 久久色在线观看| 欧美福利一区| 99av国产精品欲麻豆| 欧美亚洲午夜视频在线观看| 噜噜噜噜噜久久久久久91| 欧美丝袜第一区| 在线不卡亚洲| 亚洲综合首页| 免费一区视频| 午夜精品在线看| 欧美精品在线看| 亚洲第一级黄色片| 欧美中文在线视频| 亚洲麻豆av| 久久亚洲一区二区| 国产精品毛片| 日韩视频在线播放| 噜噜噜噜噜久久久久久91| 亚洲香蕉在线观看| 欧美日韩123| 亚洲欧洲日产国产网站| 久久久久久久久久久久久久一区 | 狠狠入ady亚洲精品| 亚洲自拍高清| 99精品国产在热久久下载| 久久综合伊人| 亚洲一区二区成人| 欧美日韩国产在线| 亚洲精选大片| 亚洲国产精品黑人久久久| 久久影视精品| 亚洲高清久久网| 久久网站免费| 久久精品免费看| 国产在线成人| 老司机一区二区| 久久福利精品| 激情偷拍久久| 女女同性女同一区二区三区91| 久久精品国产亚洲一区二区| 国产欧美日韩综合| 西西裸体人体做爰大胆久久久| 在线综合视频| 国产精品久久久久久久浪潮网站| 中文国产成人精品久久一| 夜夜精品视频| 国产乱码精品| 久久精品国内一区二区三区| 午夜精品美女久久久久av福利| 国产精品一区二区三区久久久| 欧美一级久久| 久久蜜臀精品av| 亚洲激情亚洲| 洋洋av久久久久久久一区| 欧美午夜精品久久久久久孕妇| 亚洲综合色网站| 欧美一区二区黄色| 亚洲国产毛片完整版| 亚洲精品一区在线观看| 国产精品网红福利| 理论片一区二区在线| 欧美高清在线观看| 亚洲一区网站| 久久精品在线观看| 99精品热视频| 午夜精品久久久久久久99黑人| 樱桃成人精品视频在线播放| 亚洲电影毛片| 国产精品theporn88| 久久亚洲二区| 欧美日韩亚洲一区二区三区四区| 欧美在线观看天堂一区二区三区| 久久久精品日韩欧美| 亚洲午夜免费福利视频| 欧美制服第一页| 亚洲最快最全在线视频| 亚欧成人在线| 一本一本久久a久久精品综合妖精| 午夜精品一区二区三区电影天堂| 亚洲第一中文字幕| 亚洲午夜视频在线观看| 18成人免费观看视频| 亚洲性感激情| 日韩视频免费| 久久久天天操| 午夜视频在线观看一区二区三区| 蘑菇福利视频一区播放| 久久精品国产在热久久 | 亚洲美女一区| 欧美在线免费观看| 亚洲在线视频一区| 免费日韩成人| 久久久噜噜噜久久中文字幕色伊伊 | 亚洲激情视频在线| 狠狠入ady亚洲精品经典电影| 一区二区久久久久久| 亚洲国产高清自拍| 欧美在线观看一二区| 欧美亚洲免费高清在线观看| 欧美激情女人20p| 久久久久九九九九| 国产欧美日韩在线视频| 亚洲一区二区视频| 亚洲午夜免费福利视频| 欧美精品一区二区在线播放| 另类专区欧美制服同性| 国内精品国语自产拍在线观看| 一区二区三区欧美激情| 99伊人成综合| 欧美日韩三级一区二区| 日韩亚洲欧美在线观看| 一区二区三区精品视频| 欧美欧美午夜aⅴ在线观看| 亚洲激情在线激情| 日韩天堂av| 欧美激情自拍| 亚洲精品免费网站| 99国产精品久久久| 国产精品av久久久久久麻豆网| 亚洲精品综合在线| 在线亚洲电影| 国产精品美女在线| 亚洲一区二区三区在线视频| 欧美一区2区三区4区公司二百| 国产精品乱码久久久久久| 亚洲一区二区不卡免费| 久久精品成人一区二区三区蜜臀 | 亚洲一区日韩| 国产日韩欧美在线一区| 久久久www成人免费精品| 农村妇女精品| 一本色道婷婷久久欧美| 国产女人18毛片水18精品| 久久黄色网页| 亚洲电影免费观看高清完整版在线 | 国产日本欧美视频| 欧美一区1区三区3区公司| 久久久久国产精品一区二区| 亚洲福利电影| 欧美日韩一区视频| 午夜精品久久久| 麻豆九一精品爱看视频在线观看免费 | 欧美不卡视频一区发布| 欧美精品v国产精品v日韩精品| 99国产精品久久久久久久| 欧美一区二区久久久| 一区在线视频观看| 欧美精品一区二区三区蜜桃| 亚洲一区视频在线观看视频| 久久人人爽爽爽人久久久| 一个色综合av| 伊人久久大香线蕉综合热线| 欧美日韩国产精品专区| 香蕉久久国产| 亚洲国产天堂久久综合网| 香蕉久久精品日日躁夜夜躁| 亚洲国产婷婷香蕉久久久久久99 | 亚洲综合导航| 亚洲第一视频网站| 久久成人这里只有精品| 亚洲日本精品国产第一区| 国产精品亚洲成人| 欧美激情第1页| 久久精品欧美日韩精品| 正在播放亚洲一区| 亚洲国产精品www| 久久亚洲私人国产精品va| 亚洲私拍自拍| 亚洲精品久久7777| 激情视频一区| 国产日韩亚洲欧美精品| 欧美久久久久久久久| 久热精品视频| 欧美一区二区在线播放| 一本色道久久综合狠狠躁的推荐| 欧美成人午夜视频| 久久久欧美精品sm网站|