• <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>

            S.l.e!ep.¢%

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

            HOOK SSDT Hide Process (一)

            Posted on 2009-10-24 23:58 S.l.e!ep.¢% 閱讀(370) 評論(0)  編輯 收藏 引用 所屬分類: RootKit

            [資料] http://m.shnenglu.com/sleepwom/archive/2009/10/24/99375.html

            What is SSDT?
            SSDT的全稱是System Services Descriptor Table,系統(tǒng)服務(wù)描述符表。這個表就是一個把ring3的Win32 API和ring0的內(nèi)核API聯(lián)系起來。SSDT并不僅僅只包含一個龐大的地址索引表,它還包含著一些其它有用的信息,諸如地址索引的基地址、服務(wù)函數(shù)個數(shù)等。

            How to use?
            在頭文件如此定義即可

            #pragma? pack(1)

            typedef struct _SSDT_TABLE
            {
            ? PVOID?? ServiceTableBase;
            ? PULONG? ServiceCounterTableBase;
            ? ULONG?? NumberOfService;
            ? ULONG?? ParamTableBase;
            }SSDT_TABLE,* PSSDT_TABLE;

            #pragma pack()

            extern "C" extern PSSDT_TABLE??KeServiceDescriptorTable;

            why?
            KeServiceDescriptorTable是ntoskrnl.exe導(dǎo)出的(Win下所有PE都可以導(dǎo)出接口或變量)
            用 vc 自帶的 dependency.exe 工具查看 ntoskrnl.exe 就可以看到
            609(0x0261) 594(0x0252) KeServiceDescriptorTable??? 0x0008B520?
            (另外可以看到? Nt開頭的是ntdll.dll導(dǎo)出的,ntoskrnl.exe導(dǎo)出的是Zw開頭的函數(shù) )

            可以參考以下這篇文章,里面提到系統(tǒng)服務(wù)號101h,NtTerminateProcess和ZwTerminateProcess的關(guān)系:
            內(nèi)核下,ZwXxx函數(shù)還是會走int?2e這條路,為的是把PreviousMode變?yōu)镵ernelMode。NtXxx是真正實現(xiàn)的地方。SSDT里面放的是NtXxx的函數(shù)地址。

            標(biāo)?題:?【原創(chuàng)】內(nèi)核態(tài)進(jìn)程管理器Intercessor和實現(xiàn)細(xì)節(jié)
            作?者:?greatcsk
            時?間:?2007-09-05,20:20
            鏈?接:?http://bbs.pediy.com/showthread.php?t=51157?

            try it;
            寫一個Exe程序

            .h 加上
            #pragma comment(linker, "/EXPORT:_Add,@1,NONAME")

            #ifdef __cplusplus
            extern "C" {
            #endif

            __declspec(dllexport) int Add(int a, int b);

            #ifdef __cplusplus
            }
            #endif? /* __cplusplus */

            .cpp 加上
            #ifdef __cplusplus
            extern "C" {
            #endif

            ?? int Add(int a, int b)
            ?? {
            ???? return (a + b);
            ?? }

            #ifdef __cplusplus
            }
            #endif? /* __cplusplus */

            最后加上 .def
            EXPORTS
            ?? Add??????? @1??

            生成后,發(fā)現(xiàn)有 *.lib
            用 dependency.exe 一看,確實導(dǎo)出了
            調(diào)用時,跟調(diào)用DLL的函數(shù)是一樣的

            void CTestexeexportDlg::OnButton1()
            {
            ?HMODULE moudule = ::LoadLibrary("C:\\\\exeexport.exe");

            ?typedef int(*MyFuncProc)(int a, int b);

            ?MyFuncProc pFun;

            ?pFun = (MyFuncProc)GetProcAddress(moudule, "Add");


            ?int i = pFun(10, 20);

            }



            99久久国产免费福利| 久久狠狠爱亚洲综合影院| 久久精品国产一区| 久久久久亚洲AV无码专区桃色| 国产精品久久久久一区二区三区 | 久久精品国产免费观看三人同眠| 亚洲国产精品无码久久九九| 亚洲国产精品无码久久98| 国产高潮国产高潮久久久| 国产精品免费看久久久香蕉| 久久人做人爽一区二区三区| 精品久久久久久国产潘金莲 | 一本一本久久A久久综合精品| 精品免费tv久久久久久久| 久久亚洲天堂| 精品久久久久国产免费| 久久ZYZ资源站无码中文动漫| 精品无码久久久久久国产| 久久综合综合久久综合| 久久免费视频6| 97精品国产97久久久久久免费| 色综合久久综合中文综合网| 久久无码AV中文出轨人妻| www.久久热.com| 日韩人妻无码一区二区三区久久| 热久久国产欧美一区二区精品| 国产Av激情久久无码天堂| 思思久久精品在热线热| 一本色综合久久| 亚洲欧美一区二区三区久久| 久久久久亚洲爆乳少妇无| 国産精品久久久久久久| 91精品无码久久久久久五月天| 久久精品蜜芽亚洲国产AV| 久久夜色精品国产噜噜麻豆| 久久热这里只有精品在线观看| 久久青青草原精品国产不卡| 97久久精品人人澡人人爽| 99久久国产亚洲高清观看2024| 久久精品国产精品亚洲精品| 久久精品国产亚洲AV嫖农村妇女|