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

S.l.e!ep.¢%

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

hook未導出native api的好辦法

Posted on 2009-11-04 11:39 S.l.e!ep.¢% 閱讀(410) 評論(0)  編輯 收藏 引用 所屬分類: RootKit
				
						昨天寫的那個 
hook?ssdt的驅動,用的是硬編碼的辦法,這樣在不同的系統中由于NtShutdownSystem的服務號都不相同,所以在不同的操作系統上代碼都要做修改,這個比較不爽.今天聽老大PJF說有避免硬編碼的方法,google了下,發現下面的文章,代碼稍微改了改,用在我的驅動中,果然好使.文章貼在下面:
-------------------------------------------------------------------------------------------
from?http://www.rootkit.com

Hardcoding?the?positions?seems?a?poor?solution,?since?it?means?after?a?new?service?pack,?the?rootkit?may?no?longer?work?and?become?discovered.

As?I?have?found?the?code?on?this?site?extremely?helpful,?I?think?it?is?only?fair?that?I?return?the?favour?;-)

I?have?implemented?the?method?described?in?previous?posts,?whereby?I?have?mapped?a?view?of?ntdll.dll?into?the?process?space?of?whoever?loads?the?driver?initially,?and?then?retrieve?the?required?function?positions?directly?from?the?dll.

This?was?relatively?simple?to?do,?and?only?requires?knowledge?of?the?pe?file?format,?and?a?few?undocumented?apis.

Using?the?function?pasted?below,?when?hooking?you?simply?do?as?follows:


RtlInitUnicodeString(&dllName,?L"\\Device\\HarddiskVolume1\\Windows\\System32\\ntdll.dll");
functionAddress?=?GetDllFunctionAddress(functionName,?&dllName);
position?=?*((WORD*)(functionAddress+1));
????
g_OriginalZwCreateProcessEx?=?(ZWCREATEPROCESSEX)(KeServiceDescriptorTable.ServiceTableBase[position]);


and?here's?the?function?GetDllFunctionAddress:


DWORD?GetDllFunctionAddress(char*?lpFunctionName,?PUNICODE_STRING?pDllName)?
{
????HANDLE?hThread,?hSection,?hFile,?hMod;
????SECTION_IMAGE_INFORMATION?sii;
????IMAGE_DOS_HEADER*?dosheader;
????IMAGE_OPTIONAL_HEADER*?opthdr;
????IMAGE_EXPORT_DIRECTORY*?pExportTable;
????DWORD*?arrayOfFunctionAddresses;
????DWORD*?arrayOfFunctionNames;
????WORD*?arrayOfFunctionOrdinals;
????DWORD?functionOrdinal;
????DWORD?Base,?x,?functionAddress;
????char*?functionName;
????STRING?ntFunctionName,?ntFunctionNameSearch;
????PVOID?BaseAddress?=?NULL;
????SIZE_T?size=0;

????OBJECT_ATTRIBUTES?oa?=?{sizeof?oa,?0,?pDllName,?OBJ_CASE_INSENSITIVE};

????IO_STATUS_BLOCK?iosb;

????//_asm?int?3;
????ZwOpenFile(&hFile,?FILE_EXECUTE?|?SYNCHRONIZE,?&oa,?&iosb,?FILE_SHARE_READ,?FILE_SYNCHRONOUS_IO_NONALERT);

????oa.ObjectName?=?0;

????ZwCreateSection(&hSection,?SECTION_ALL_ACCESS,?&oa,?0,PAGE_EXECUTE,?SEC_IMAGE,?hFile);
????
????ZwMapViewOfSection(hSection,?NtCurrentProcess(),?&BaseAddress,?0,?1000,?0,?&size,?(SECTION_INHERIT)1,?MEM_TOP_DOWN,?PAGE_READWRITE);?
????
????ZwClose(hFile);
????
????hMod?=?BaseAddress;
????
????dosheader?=?(IMAGE_DOS_HEADER?*)hMod;
????
????opthdr?=(IMAGE_OPTIONAL_HEADER?*)?((BYTE*)hMod+dosheader->e_lfanew+24);

????pExportTable?=(IMAGE_EXPORT_DIRECTORY*)((BYTE*)?hMod?+?opthdr->DataDirectory[?IMAGE_DIRECTORY_ENTRY_EXPORT].?VirtualAddress);

????//?now?we?can?get?the?exported?functions,?but?note?we?convert?from?RVA?to?address
????arrayOfFunctionAddresses?=?(DWORD*)(?(BYTE*)hMod?+?pExportTable->AddressOfFunctions);

????arrayOfFunctionNames?=?(DWORD*)(?(BYTE*)hMod?+?pExportTable->AddressOfNames);

????arrayOfFunctionOrdinals?=?(WORD*)(?(BYTE*)hMod?+?pExportTable->AddressOfNameOrdinals);

????Base?=?pExportTable->Base;

????RtlInitString(&ntFunctionNameSearch,?lpFunctionName);

????for(x?=?0;?x?<?pExportTable->NumberOfFunctions;?x++)
????{
????????functionName?=?(char*)(?(BYTE*)hMod?+?arrayOfFunctionNames[x]);

????????RtlInitString(&ntFunctionName,?functionName);

????????functionOrdinal?=?arrayOfFunctionOrdinals[x]?+?Base?-?1;?//?always?need?to?add?base,?-1?as?array?counts?from?0
????????//?this?is?the?funny?bit.??you?would?expect?the?function?pointer?to?simply?be?arrayOfFunctionAddresses[x]...
????????//?oh?no...?thats?too?simple.??it?is?actually?arrayOfFunctionAddresses[functionOrdinal]!!
????????functionAddress?=?(DWORD)(?(BYTE*)hMod?+?arrayOfFunctionAddresses[functionOrdinal]);
????????if?(RtlCompareString(&ntFunctionName,?&ntFunctionNameSearch,?TRUE)?==?0)?
????????{
????????????ZwClose(hSection);
????????????return?functionAddress;
????????}
????}

????ZwClose(hSection);
????return?0;
}
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            中文在线不卡视频| 亚洲日本久久| 久久www成人_看片免费不卡| 亚洲欧美国内爽妇网| 国产视频久久久久久久| 久久亚洲欧美国产精品乐播| 久久久综合视频| 亚洲精品美女在线| 99热在线精品观看| 国产亚洲成年网址在线观看| 噜噜噜91成人网| 欧美理论电影在线播放| 性欧美xxxx大乳国产app| 久久精品30| 99re66热这里只有精品3直播| 日韩一级黄色av| 国产亚洲成人一区| 亚洲三级电影全部在线观看高清| 欧美午夜理伦三级在线观看| 久久精品夜色噜噜亚洲a∨ | 欧美一区二区黄| 久久国产日韩| 亚洲私人影院| 久久人人看视频| 午夜精品www| 欧美成人综合| 久久成人亚洲| 欧美日韩不卡一区| 久久婷婷国产综合尤物精品 | 亚洲免费高清视频| 红桃视频亚洲| 亚洲香蕉在线观看| 亚洲精品午夜精品| 欧美自拍偷拍| 亚洲欧美日韩成人高清在线一区| 麻豆av福利av久久av| 亚洲视频免费在线| 另类av导航| 久久精品国产99国产精品| 欧美日韩精品系列| 欧美成人一区二区三区| 国产日韩视频一区二区三区| 亚洲精品国久久99热| 影音先锋一区| 欧美一区二区三区四区高清| 亚洲一区久久| 欧美日韩高清不卡| 亚洲激情六月丁香| 亚洲国产精品成人精品| 欧美亚洲在线观看| 亚洲欧美三级伦理| 欧美日韩综合久久| 亚洲人成在线播放| 亚洲日本欧美| 欧美激情视频一区二区三区免费| 免费av成人在线| 精品91视频| 久久久国产精品亚洲一区| 久久av红桃一区二区小说| 国产精品久久久久久久久借妻| 亚洲精品一区在线| 亚洲视频一区二区在线观看 | 久久久久久电影| 久久亚洲美女| 亚洲福利精品| 模特精品在线| 亚洲欧洲日产国码二区| 亚洲美女尤物影院| 欧美日本久久| 中文精品99久久国产香蕉| 亚洲午夜高清视频| 国产精品每日更新在线播放网址| 一本色道久久综合亚洲精品按摩| 亚洲影视九九影院在线观看| 国产精品毛片a∨一区二区三区|国| 亚洲天堂av在线免费| 性娇小13――14欧美| 国内成+人亚洲| 久久亚洲精品伦理| 91久久国产综合久久91精品网站| 99re6热只有精品免费观看| 欧美美女操人视频| 亚洲一区三区在线观看| 久久手机精品视频| 亚洲精品国产精品国自产观看浪潮| 欧美激情国产高清| 亚洲一区影音先锋| 欧美v日韩v国产v| 一区二区三区精品| 国产亚洲在线| 欧美激情中文不卡| 亚洲欧美日韩国产一区| 欧美成年视频| 亚洲一区在线直播| 精品69视频一区二区三区| 欧美日本精品| 久久国产欧美精品| 亚洲精品少妇网址| 久久久久成人网| 亚洲精品日日夜夜| 国产又爽又黄的激情精品视频| 女人香蕉久久**毛片精品| 亚洲色图制服丝袜| 欧美激情一区二区| 欧美一区二视频在线免费观看| 亚洲电影免费观看高清| 国产精品99免费看 | 制服丝袜激情欧洲亚洲| 国产中文一区二区| 欧美日韩一区二区三| 久久噜噜噜精品国产亚洲综合| 一本到高清视频免费精品| 免费欧美日韩国产三级电影| 亚洲永久免费观看| 日韩视频―中文字幕| 揄拍成人国产精品视频| 国产精品美女主播在线观看纯欲| 猛男gaygay欧美视频| 欧美一区激情| 亚洲欧美国产视频| 亚洲午夜高清视频| 日韩一级黄色av| 亚洲国产成人精品久久| 裸体素人女欧美日韩| 久久国产精品黑丝| 亚洲影视在线| 亚洲午夜精品网| av成人黄色| 一本色道久久综合亚洲精品高清| 亚洲国产欧美在线| 极品日韩久久| 国产一区在线观看视频| 国产农村妇女精品| 国产精品视频99| 国产精品入口麻豆原神| 国产精品久久久一区二区| 欧美日韩大陆在线| 欧美偷拍一区二区| 欧美日在线观看| 国产精品久久久久久久午夜| 欧美日韩在线不卡| 欧美午夜无遮挡| 欧美午夜宅男影院在线观看| 欧美日韩一区三区四区| 欧美色网在线| 国产精品黄色| 国产欧美一区二区三区在线老狼| 国产精品欧美激情| 国产欧美视频一区二区| 国产视频精品xxxx| 在线成人性视频| 亚洲激情黄色| 一区二区欧美激情| 欧美一级视频精品观看| 久久国产日本精品| 欧美成年人视频| 亚洲全部视频| 亚洲午夜精品一区二区三区他趣| 亚洲午夜高清视频| 久久久精品日韩欧美| 欧美成人精品在线播放| 欧美日韩人人澡狠狠躁视频| 国产精品区一区二区三区| 国产一级久久| 亚洲日本电影| 欧美一级网站| 亚洲高清在线观看一区| 一二三四社区欧美黄| 欧美在线亚洲一区| 欧美高清在线精品一区| 国产精品久久久久久久久婷婷| 国产日韩欧美在线播放| 最新高清无码专区| 午夜国产精品影院在线观看 | 蜜桃av久久久亚洲精品| 亚洲精品国产无天堂网2021| 亚洲一区二区三区四区在线观看| 久久精品卡一| 欧美性猛交xxxx乱大交退制版 | 国产精品不卡在线| 一区在线观看| 亚洲综合视频网| 欧美a级大片| 亚洲欧美日韩久久精品| 欧美黄色免费网站| 国产一级揄自揄精品视频| 一本久久a久久精品亚洲| 久久久久成人精品| 国产精品99久久久久久久女警 | 噜噜爱69成人精品| 国产乱子伦一区二区三区国色天香| 亚洲成色www8888| 久久大综合网| 一区二区三区四区五区精品| 久久只精品国产| 国产亚洲精品v| 午夜激情久久久| 99re6这里只有精品视频在线观看| 久久天天躁狠狠躁夜夜爽蜜月| 国产精品一区二区久久久|