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

road420

導(dǎo)航

<2025年12月>
30123456
78910111213
14151617181920
21222324252627
28293031123
45678910

統(tǒng)計(jì)

常用鏈接

留言簿(2)

隨筆檔案

文章檔案

搜索

最新評(píng)論

閱讀排行榜

評(píng)論排行榜

CreateRemoteThread

CreateRemoteThread提供了一個(gè)在遠(yuǎn)程進(jìn)程中執(zhí)行代碼的方法,就像代碼長出翅膀飛到別處運(yùn)行。本文將做一個(gè)入門介紹,希望對(duì)廣大編程愛好者有所幫助。

先解釋一下遠(yuǎn)程進(jìn)程,其實(shí)就是要植入你的代碼的進(jìn)程,相對(duì)于你的工作進(jìn)程(如果叫本地進(jìn)程的話)它就叫遠(yuǎn)程進(jìn)程,可理解為宿主。

首先介紹一下我們的主要工具CreateRemoteThread,這里先將函數(shù)原型簡單介紹以下。

CreateRemoteThread可將線程創(chuàng)建在遠(yuǎn)程進(jìn)程中。

函數(shù)原型
HANDLE CreateRemoteThread(
HANDLE hProcess,                          // handle to process
LPSECURITY_ATTRIBUTES lpThreadAttributes, // SD
SIZE_T dwStackSize,                       // initial stack size
LPTHREAD_START_ROUTINE lpStartAddress,    // thread function
LPVOID lpParameter,                       // thread argument
DWORD dwCreationFlags,                    // creation option
LPDWORD lpThreadId                        // thread identifier
);
參數(shù)說明:
hProcess
[輸入] 進(jìn)程句柄
lpThreadAttributes
[輸入] 線程安全描述字,指向SECURITY_ATTRIBUTES結(jié)構(gòu)的指針
dwStackSize
[輸入] 線程棧大小,以字節(jié)表示
lpStartAddress
[輸入] 一個(gè)LPTHREAD_START_ROUTINE類型的指針,指向在遠(yuǎn)程進(jìn)程中執(zhí)行的函數(shù)地址
lpParameter
[輸入] 傳入?yún)?shù)
dwCreationFlags
[輸入] 創(chuàng)建線程的其它標(biāo)志

lpThreadId
[輸出] 線程身份標(biāo)志,如果為NULL,則不返回

返回值
成功返回新線程句柄,失敗返回NULL,并且可調(diào)用GetLastError獲得錯(cuò)誤值。

接下來我們將以兩種方式使用CreateRemoteThread,大家可以領(lǐng)略到CreateRemoteThread的神通,它使你的代碼可以脫離你的進(jìn)程,植入到別的進(jìn)程中運(yùn)行。


第一種方式

第一種方式,我們使用函數(shù)的形式。即我們將自己程序中的一個(gè)函數(shù)植入到遠(yuǎn)程進(jìn)程中。

步驟1:首先在你的進(jìn)程中創(chuàng)建函數(shù)MyFunc,我們將把它放在另一個(gè)進(jìn)程中運(yùn)行,這里以windows

計(jì)算器為目標(biāo)進(jìn)程。
static DWORD WINAPI MyFunc (LPVOID pData)
{
//do something
//...
//pData輸入項(xiàng)可以是任何類型值
//這里我們會(huì)傳入一個(gè)DWORD的值做示例,并且簡單返回
return *(DWORD*)pData;
}
static void AfterMyFunc (void) {
}
這里有個(gè)小技巧,定義了一個(gè)static void AfterMyFunc (void);為了下面確定我們的代碼大小

步驟2:定位目標(biāo)進(jìn)程,這里是一個(gè)計(jì)算器
HWND hStart = ::FindWindow (TEXT("SciCalc"),NULL);

步驟3:獲得目標(biāo)進(jìn)程句柄,這里用到兩個(gè)不太常用的函數(shù)(當(dāng)然如果經(jīng)常做線程/進(jìn)程等方面的 項(xiàng)目的話,就很面熟了),但及有用
DWORD PID, TID;
TID = ::GetWindowThreadProcessId (hStart, &PID);

HANDLE hProcess;
hProcess = OpenProcess(PROCESS_ALL_ACCESS,false,PID);

步驟4:在目標(biāo)進(jìn)程中配變量地址空間,這里我們分配10個(gè)字節(jié),并且設(shè)定為可以讀

寫PAGE_READWRITE,當(dāng)然也可設(shè)為只讀等其它標(biāo)志,這里就不一一說明了。
char szBuffer[10];
*(DWORD*)szBuffer=1000;//for test
void *pDataRemote =(char*) VirtualAllocEx( hProcess, 0, sizeof(szBuffer), MEM_COMMIT,

PAGE_READWRITE );

步驟5:寫內(nèi)容到目標(biāo)進(jìn)程中分配的變量空間
::WriteProcessMemory( hProcess, pDataRemote, szBuffer,(sizeof(szBuffer),NULL);

步驟6:在目標(biāo)進(jìn)程中分配代碼地址空間
計(jì)算代碼大小
DWORD cbCodeSize=((LPBYTE) AfterMyFunc - (LPBYTE) MyFunc);
分配代碼地址空間
PDWORD pCodeRemote = (PDWORD) VirtualAllocEx( hProcess, 0, cbCodeSize, MEM_COMMIT,

PAGE_EXECUTE_READWRITE );

步驟7:寫內(nèi)容到目標(biāo)進(jìn)程中分配的代碼地址空間
WriteProcessMemory( hProcess, pCodeRemote, &MyFunc, cbCodeSize, NULL);

步驟8:在目標(biāo)進(jìn)程中執(zhí)行代碼

HANDLE hThread = CreateRemoteThread(hProcess, NULL, 0,
(LPTHREAD_START_ROUTINE) pCodeRemote,
pDataRemote, 0 , NULL);
DWORD h;
if (hThread)
{
::WaitForSingleObject( hThread, INFINITE );
::GetExitCodeThread( hThread, &h );
TRACE("run and return %d\n",h);
::CloseHandle( hThread );
}

這里有幾個(gè)值得說明的地方:
使用WaitForSingleObject等待線程結(jié)束;
使用GetExitCodeThread獲得返回值;
最后關(guān)閉句柄CloseHandle。

步驟9:清理現(xiàn)場

釋放空間
::VirtualFreeEx( hProcess, pCodeRemote,
                 cbCodeSize,MEM_RELEASE );

::VirtualFreeEx( hProcess, pDataRemote,
                 cbParamSize,MEM_RELEASE );

關(guān)閉進(jìn)程句柄
::CloseHandle( hProcess );

 

第二種方式

第二種方式,我們使用動(dòng)態(tài)庫的形式。即我們將自己一個(gè)動(dòng)態(tài)庫植入到遠(yuǎn)程進(jìn)程中。

這里不再重復(fù)上面相同的步驟,只寫出其中關(guān)鍵的地方.
關(guān)鍵1:
在步驟5中將動(dòng)態(tài)庫的路徑作為變量傳入變量空間.
關(guān)鍵2:
在步驟8中,將GetProcAddress作為目標(biāo)執(zhí)行函數(shù).

hThread = ::CreateRemoteThread( hProcess, NULL, 0,
            (LPTHREAD_START_ROUTINE )::GetProcAddress(
             hModule, "LoadLibraryA"),
             pDataRemote, 0, NULL );


另外在步驟9,清理現(xiàn)場中首先要先進(jìn)行釋放我們的動(dòng)態(tài)庫.也即類似步驟8執(zhí)行函數(shù)FreeLibrary

hThread = ::CreateRemoteThread( hProcess, NULL, 0,
(LPTHREAD_START_ROUTINE )::GetProcAddress(
hModule, "FreeLibrary"),
(void*)hLibModule, 0, NULL );

好了,限于篇幅不能夠介紹的很細(xì),在使用過程中如有疑問可向作者咨詢.(開發(fā)環(huán)境:windows2000/vc6.0)
 

 


本文來自CSDN博客,轉(zhuǎn)載請(qǐng)標(biāo)明出處:http://blog.csdn.net/fangchao918628/archive/2008/08/30/2852744.aspx

posted on 2010-09-16 14:05 深邃者 閱讀(563) 評(píng)論(0)  編輯 收藏 引用


只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲日本一区二区| 久久女同互慰一区二区三区| 亚洲国产91精品在线观看| 久久精品国产999大香线蕉| 国产日韩视频一区二区三区| 欧美一区二区在线| 欧美亚洲一级| 亚洲大胆av| 亚洲国产精品成人精品| 欧美人与性动交cc0o| 亚洲一区二区三区影院| 亚洲一品av免费观看| 国产日韩欧美三区| 牛夜精品久久久久久久99黑人| 久久综合色8888| aa成人免费视频| 亚洲制服丝袜在线| 在线观看日韩国产| 亚洲免费观看视频| 国产亚洲福利一区| 欧美国产第二页| 欧美日韩精品久久| 久久精品国产一区二区三| 美女91精品| 9色porny自拍视频一区二区| 一区二区高清| 韩国三级电影一区二区| 亚洲国产精品成人一区二区 | 久久久久网址| 亚洲精品社区| 午夜精品久久久久久| 亚洲国产成人久久综合| 一本色道久久综合亚洲精品不| 国产欧美亚洲一区| 欧美激情影音先锋| 国产午夜精品理论片a级探花 | 性色av一区二区三区在线观看| 久久久久一区二区三区| 亚洲一区二区网站| 久久久99爱| 午夜精品久久久久久久久久久久 | 亚洲欧美国产制服动漫| 亚洲国产综合91精品麻豆| 亚洲私人影院| 亚洲欧洲精品一区二区| 午夜在线电影亚洲一区| 这里只有视频精品| 另类图片综合电影| 久久久国产亚洲精品| 欧美日韩午夜剧场| 亚洲激情不卡| 在线不卡中文字幕| 亚洲欧美中文在线视频| 99精品福利视频| 久久婷婷国产综合精品青草| 欧美在线在线| 国产精品一区亚洲| 亚洲视频在线一区观看| 亚洲日本视频| 免费欧美日韩| 另类国产ts人妖高潮视频| 国产乱码精品一区二区三区不卡| 亚洲免费不卡| 在线综合+亚洲+欧美中文字幕| 嫩草国产精品入口| 老巨人导航500精品| 国产一区二区三区精品欧美日韩一区二区三区| 亚洲激情亚洲| 亚洲日本欧美天堂| 欧美劲爆第一页| 你懂的视频欧美| 亚洲成色777777在线观看影院| 性欧美videos另类喷潮| 欧美一区二区视频97| 国产精品亚洲片夜色在线| 日韩网站在线| 亚洲在线第一页| 国产伦精品一区二区| 亚洲综合欧美日韩| 久久高清免费观看| 国户精品久久久久久久久久久不卡 | 在线欧美一区| 欧美a级一区二区| 亚洲国产精品女人久久久| 日韩视频免费在线观看| 欧美日韩国产一级| 亚洲在线免费| 久久精品国产综合精品| 在线成人激情视频| 免费看的黄色欧美网站| 亚洲日本va在线观看| 亚洲综合色网站| 国产日韩一区在线| 欧美 日韩 国产一区二区在线视频 | 亚洲欧美欧美一区二区三区| 国产日韩一区二区三区| 麻豆av一区二区三区| 亚洲日本乱码在线观看| 亚洲一区综合| 激情亚洲一区二区三区四区| 欧美xart系列高清| 亚洲一区二区三| 欧美高清在线视频观看不卡| 这里只有精品丝袜| 一区二区三区中文在线观看 | 欧美激情亚洲自拍| 亚洲欧美日韩直播| 亚洲电影中文字幕| 亚洲一区二区动漫| 精品1区2区3区4区| 欧美日韩一区高清| 久久综合电影| 亚洲午夜精品一区二区三区他趣| 久久综合狠狠综合久久综合88| 日韩视频在线你懂得| 国产一区二区久久| 欧美色偷偷大香| 欧美va天堂va视频va在线| 亚洲欧美另类国产| 亚洲精品免费观看| 欧美高清不卡| 欧美一区二区黄| 夜夜嗨av一区二区三区中文字幕| 激情久久综合| 国产精品日韩一区| 欧美日韩午夜激情| 欧美xart系列在线观看| 欧美一区二区三区精品电影| 亚洲精品中文字幕在线| 欧美成人tv| 久久久蜜臀国产一区二区| 欧美一区二区三区在线观看| 国产精品99久久久久久人| 亚洲精品色图| 亚洲精品国产精品国产自| 伊人婷婷欧美激情| 国产一区二区三区日韩| 国产精品亚洲网站| 欧美性淫爽ww久久久久无| 欧美精品日韩一本| 欧美激情第4页| 毛片一区二区三区| 老色鬼精品视频在线观看播放| 欧美中文在线观看| 欧美一二三区精品| 欧美一激情一区二区三区| 校园春色国产精品| 欧美一区二区三区免费观看 | 亚洲精品国产拍免费91在线| 亚洲高清视频的网址| 欧美国产91| 亚洲国产综合在线看不卡| 欧美韩日一区| 亚洲国产日韩欧美在线99| 亚洲国产精品视频| 91久久黄色| 一本一本大道香蕉久在线精品| 一区二区成人精品| 午夜精品视频在线观看一区二区| 亚洲午夜女主播在线直播| 亚洲一区二区黄| 亚洲影视在线| 欧美在线国产| 免费久久精品视频| 欧美日韩精品中文字幕| 国产精品v亚洲精品v日韩精品| 国产精品乱子乱xxxx| 国产一区二区三区最好精华液| 伊人成年综合电影网| 一二三区精品福利视频| 午夜精品久久久久久久久久久久 | 久久亚洲午夜电影| 欧美国产日产韩国视频| 日韩视频一区二区在线观看| 亚洲午夜黄色| 久久久久久有精品国产| 欧美激情在线有限公司| 国产精品日韩一区| 亚洲东热激情| 亚洲专区在线视频| 免费在线成人| 亚洲免费观看高清完整版在线观看熊| 亚洲影视综合| 蜜臀久久99精品久久久画质超高清| 欧美日韩国产色站一区二区三区| 国产女人水真多18毛片18精品视频| 亚洲国产成人一区| 欧美在线精品一区| 亚洲级视频在线观看免费1级| 亚洲主播在线| 欧美—级在线免费片| 韩国一区二区三区在线观看 | 亚洲免费成人av| 久久久91精品国产一区二区精品| 亚洲黄一区二区三区| 欧美尤物巨大精品爽| 欧美四级在线| 亚洲日本免费| 开元免费观看欧美电视剧网站| 一区二区三区国产精华|