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

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.¢% 閱讀(412) 評論(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>
            欧美午夜在线| 国产精品一区二区三区观看| 精品成人一区| 欧美成年人在线观看| 久久精品中文字幕一区二区三区| 狠狠88综合久久久久综合网| 久久亚洲国产精品日日av夜夜| 久久精品亚洲一区二区三区浴池| 国产婷婷精品| 免费欧美在线视频| 欧美精品福利在线| 亚洲欧美日韩一区二区三区在线| 午夜精品久久久久久久男人的天堂| 国产综合视频| 亚洲黄色免费电影| 欧美日韩美女一区二区| 午夜老司机精品| 久久久999精品免费| 99亚洲一区二区| 亚洲老司机av| 亚洲午夜视频| 亚洲国产老妈| 一区二区免费在线视频| 狠狠爱www人成狠狠爱综合网| 亚洲国产你懂的| 国产精品成人一区二区三区吃奶| 久久久精品国产一区二区三区| 老司机午夜精品视频| 亚洲午夜视频在线观看| 久久精品国产亚洲aⅴ| 亚洲黄一区二区| 亚洲欧美成人| 夜夜精品视频| 久久精品欧美| 性色av一区二区三区在线观看| 久久精品视频va| 亚洲欧美激情视频| 欧美电影免费| 久久久av水蜜桃| 欧美巨乳在线观看| 女生裸体视频一区二区三区| 国产精品久久久久久模特| 欧美11—12娇小xxxx| 国产女主播视频一区二区| 亚洲国产高清自拍| 精品1区2区| 亚洲欧美日韩久久精品| 亚洲一区二区三区四区在线观看| 久久夜色精品国产亚洲aⅴ| 久久本道综合色狠狠五月| 欧美日韩在线电影| 亚洲第一主播视频| 今天的高清视频免费播放成人| 亚洲免费人成在线视频观看| 亚洲一区二区三区高清 | 欧美777四色影视在线| 欧美亚男人的天堂| 亚洲欧洲三级| 亚洲精品亚洲人成人网| 久久亚洲春色中文字幕| 久久久五月婷婷| 韩国v欧美v日本v亚洲v| 欧美一区二区三区成人| 欧美一区在线看| 国产精品一区二区三区乱码| 在线亚洲国产精品网站| 亚洲欧美高清| 国产精品免费福利| 亚洲综合导航| 久久成人精品无人区| 国产日韩专区在线| 欧美一区二区三区在线观看| 久久精品一区二区三区不卡| 国产日本亚洲高清| 久久99伊人| 欧美91精品| 亚洲理伦电影| 欧美午夜精品久久久久久超碰| 一区二区久久| 久久久不卡网国产精品一区| 国内精品美女在线观看| 欧美有码视频| 亚洲成人在线网站| 亚洲午夜激情| 国产麻豆综合| 久久午夜色播影院免费高清| 亚洲国产精品999| 这里只有精品视频在线| 国产精品制服诱惑| 久久久久国色av免费观看性色| 欧美激情在线有限公司| 亚洲色无码播放| 国产一区二区观看| 欧美va天堂在线| 亚洲视频一区二区在线观看 | 黑人操亚洲美女惩罚| 久久久久久久成人| 亚洲精品系列| 久久久久久久999| 91久久久精品| 国产精品亚洲综合色区韩国| 久久免费视频网| 一卡二卡3卡四卡高清精品视频| 久久精品av麻豆的观看方式| 亚洲精品美女91| 国产日韩欧美视频在线| 欧美福利视频在线| 欧美一区二区精品在线| 亚洲日本成人女熟在线观看| 国产一区二区三区的电影| 欧美成人免费在线观看| 亚洲欧美视频在线| 欧美激情精品久久久久| 欧美伊久线香蕉线新在线| 亚洲精品日韩激情在线电影| 国产精品一区二区在线观看| 欧美韩国日本一区| 久久高清免费观看| 在线视频一区观看| 亚洲激情第一页| 久久一区二区精品| 午夜日韩福利| 亚洲一区二区不卡免费| 亚洲国产欧美久久| 狠狠色丁香久久婷婷综合_中| 国产精品高精视频免费| 欧美黄污视频| 欧美成年视频| 久久婷婷国产综合精品青草| 先锋影音网一区二区| 一本久道综合久久精品| 亚洲精品九九| 亚洲国产欧美久久| 欧美高清在线精品一区| 久久亚洲综合网| 久久米奇亚洲| 久久经典综合| 久久久蜜桃一区二区人| 欧美与黑人午夜性猛交久久久| 亚洲一区二区三区四区视频 | 国产乱子伦一区二区三区国色天香| 欧美精品日韩三级| 蜜臀av性久久久久蜜臀aⅴ| 久久精品国产成人| 久久国产精品久久精品国产| 小辣椒精品导航| 校园春色国产精品| 久久大综合网| 久久久久久夜| 农夫在线精品视频免费观看| 免费日韩视频| 欧美精品久久久久久| 欧美区国产区| 欧美色欧美亚洲另类七区| 欧美午夜不卡| 国产伦精品一区二区三区免费 | 欧美日本一区| 国产精品国产福利国产秒拍| 国产精品久久久久久久第一福利 | 欧美成人精品三级在线观看| 免费一级欧美片在线播放| 免费日韩av| 欧美三级网址| 国产美女一区二区| 在线精品视频免费观看| 亚洲精品一区在线观看香蕉| 日韩亚洲欧美精品| 午夜久久久久久| 麻豆av一区二区三区| 亚洲国产91| 亚洲主播在线| 久久在线精品| 欧美日韩中文精品| 国产视频不卡| 亚洲精品自在在线观看| 午夜一区二区三区在线观看| 久久综合成人精品亚洲另类欧美| 欧美福利影院| 中文无字幕一区二区三区| 久久久国产一区二区| 欧美伦理a级免费电影| 国产欧美综合在线| 亚洲日韩欧美视频一区| 香蕉久久a毛片| 亚洲二区在线视频| 性欧美大战久久久久久久免费观看| 久久久另类综合| 国产精品久久毛片a| 亚洲福利免费| 久久国产精品电影| 亚洲精品国产视频| 久久久91精品国产一区二区三区 | 国产精品一区免费在线观看| 亚洲国产精品小视频| 性欧美1819性猛交| 亚洲全部视频| 久久午夜视频| 国产亚洲欧美日韩日本| 亚洲小说欧美另类社区| 欧美国产激情二区三区|