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

S.l.e!ep.¢%

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

hook未導(dǎo)出native api的好辦法

Posted on 2009-11-04 11:39 S.l.e!ep.¢% 閱讀(415) 評(píng)論(0)  編輯 收藏 引用 所屬分類: RootKit
				
						昨天寫(xiě)的那個(gè) 
hook?ssdt的驅(qū)動(dòng),用的是硬編碼的辦法,這樣在不同的系統(tǒng)中由于NtShutdownSystem的服務(wù)號(hào)都不相同,所以在不同的操作系統(tǒng)上代碼都要做修改,這個(gè)比較不爽.今天聽(tīng)老大PJF說(shuō)有避免硬編碼的方法,google了下,發(fā)現(xiàn)下面的文章,代碼稍微改了改,用在我的驅(qū)動(dòng)中,果然好使.文章貼在下面:
-------------------------------------------------------------------------------------------
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>
            久久久天天操| 国产日韩综合| 国产亚洲欧洲997久久综合| 精品二区视频| 亚洲视频一区二区| 久久久久久久久伊人| 亚洲福利久久| 亚洲专区一区| 欧美韩日高清| 国产欧美精品va在线观看| 亚洲狠狠丁香婷婷综合久久久| 亚洲午夜激情| 美日韩丰满少妇在线观看| 一本色道久久加勒比精品| 久久久久这里只有精品| 欧美色图一区二区三区| 在线看成人片| 午夜精品福利视频| 亚洲国产精品成人va在线观看| 亚洲一区二区在线| 欧美88av| 国内精品久久久久影院薰衣草| 一本色道久久精品| 狂野欧美激情性xxxx欧美| 亚洲色图综合久久| 免费不卡在线视频| 国产视频精品免费播放| 亚洲天堂视频在线观看| 免费中文字幕日韩欧美| 亚洲欧美日韩国产一区二区三区| 欧美成人一区二区三区| 国语自产偷拍精品视频偷| 亚洲男人的天堂在线| 亚洲国产精品123| 久久久999精品视频| 国产精品亚洲网站| 一区二区三区偷拍| 欧美99在线视频观看| 欧美影院视频| 国产精品女人网站| 一区二区欧美日韩视频| 欧美激情国产精品| 久久狠狠亚洲综合| 国产麻豆日韩欧美久久| 亚洲淫性视频| 99re6这里只有精品| 欧美成人亚洲成人日韩成人| 亚洲国产高清aⅴ视频| 久久噜噜亚洲综合| 午夜在线观看欧美| 国产精品视频| 午夜精品久久久久久久| 99国产麻豆精品| 欧美美女视频| 亚洲精品一区二区三区av| 女人色偷偷aa久久天堂| 久久免费高清视频| 黄色小说综合网站| 久久久久久久久综合| 欧美专区在线观看| 国产夜色精品一区二区av| 久久成人免费电影| 午夜精彩视频在线观看不卡| 国产精品一区毛片| 午夜伦理片一区| 亚洲在线电影| 国产一区二区在线观看免费| 久久久久久久91| 久久国产精品久久久久久久久久| 国产主播一区二区| 久久久久久久综合狠狠综合| 欧美中文在线观看国产| 狠狠色狠狠色综合系列| 久热爱精品视频线路一| 久久久最新网址| 亚洲黄色片网站| 亚洲国产第一页| 欧美日韩午夜精品| 亚洲欧美清纯在线制服| 午夜久久影院| 尹人成人综合网| 亚洲成色999久久网站| 欧美精品v日韩精品v韩国精品v| 99在线热播精品免费| 日韩一级欧洲| 国产精品伊人日日| 久久色在线观看| 免费高清在线一区| 99riav国产精品| 亚洲午夜女主播在线直播| 国产农村妇女毛片精品久久麻豆 | 国产视频一区在线| 久久久久久尹人网香蕉| 久久亚洲免费| 日韩亚洲欧美综合| 一本色道久久综合亚洲二区三区| 国产女优一区| 男人的天堂成人在线| 欧美大片一区二区| 亚洲在线观看视频| 久久精品国产亚洲5555| 日韩一级精品| 亚洲综合欧美日韩| 亚洲国产老妈| 一区二区三区日韩在线观看| 国产一区二区日韩| 亚洲第一福利社区| 国产精品久久久久一区二区三区 | 免费日韩视频| 亚洲午夜免费视频| 久久成人免费网| 99国产精品久久久久老师| 亚洲一区自拍| 亚洲欧洲日本在线| 亚洲尤物影院| 亚洲精品在线视频| 亚洲综合色丁香婷婷六月图片| 在线观看91精品国产入口| 亚洲美女网站| 一区二区三区在线看| 日韩一级欧洲| 亚洲国产精品成人| 亚洲免费小视频| 亚洲日本va午夜在线影院| 亚洲午夜一二三区视频| 亚洲激情综合| 午夜国产精品视频免费体验区| 亚洲美女网站| 久久riav二区三区| 亚洲性色视频| 免费日韩视频| 久久久久国产精品厨房| 欧美日韩国产限制| 免费一级欧美在线大片| 国产精品揄拍500视频| 91久久精品国产91性色| 黑人一区二区| 亚洲天堂激情| 这里是久久伊人| 免费成年人欧美视频| 久久看片网站| 国产精品自拍在线| 亚洲另类视频| 亚洲日本欧美在线| 久久精品国产久精国产思思| 亚洲欧美激情诱惑| 欧美国产日韩免费| 另类天堂av| 国产日韩视频一区二区三区| 一本久久a久久免费精品不卡| 亚洲激情电影中文字幕| 欧美在线亚洲| 欧美在线亚洲一区| 国产精品久久久久久久久久ktv | 亚洲欧美成人一区二区在线电影 | 国产精品高清在线| 最新成人在线| 亚洲激精日韩激精欧美精品| 久久狠狠婷婷| 久久精品一区蜜桃臀影院 | 久久视频在线视频| 国产欧美日韩激情| 亚洲手机在线| 午夜精品一区二区三区电影天堂 | 国产欧美91| 在线视频精品一| 中文精品一区二区三区| 欧美精品九九| 亚洲精品国产精品国产自| 亚洲国产乱码最新视频| 久久免费少妇高潮久久精品99| 久久久久久午夜| 国产亚洲亚洲| 久久久999国产| 你懂的国产精品| 亚洲成色精品| 美日韩在线观看| 欧美激情免费在线| 亚洲精品国产视频| 欧美剧在线免费观看网站| 亚洲人成小说网站色在线| 一本色道久久加勒比88综合| 欧美日韩免费观看中文| 99国产精品视频免费观看一公开| 亚洲一区二区av电影| 欧美午夜不卡| 亚洲综合国产激情另类一区| 欧美中文字幕在线播放| 国产一区二区三区在线观看视频 | 欧美日产国产成人免费图片| 亚洲毛片在线| 亚洲专区欧美专区| 国产精品制服诱惑| 久久高清福利视频| 欧美成人精品一区二区| 亚洲精品影视| 欧美午夜免费影院| 亚洲欧美日韩国产中文在线| 久久婷婷影院| 亚洲精品免费电影|