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

road420

導航

<2008年7月>
293012345
6789101112
13141516171819
20212223242526
272829303112
3456789

統計

常用鏈接

留言簿(2)

隨筆檔案

文章檔案

搜索

最新評論

閱讀排行榜

評論排行榜

CreateRemoteThread

CreateRemoteThread提供了一個在遠程進程中執行代碼的方法,就像代碼長出翅膀飛到別處運行。本文將做一個入門介紹,希望對廣大編程愛好者有所幫助。

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

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

CreateRemoteThread可將線程創建在遠程進程中。

函數原型
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
);
參數說明:
hProcess
[輸入] 進程句柄
lpThreadAttributes
[輸入] 線程安全描述字,指向SECURITY_ATTRIBUTES結構的指針
dwStackSize
[輸入] 線程棧大小,以字節表示
lpStartAddress
[輸入] 一個LPTHREAD_START_ROUTINE類型的指針,指向在遠程進程中執行的函數地址
lpParameter
[輸入] 傳入參數
dwCreationFlags
[輸入] 創建線程的其它標志

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

返回值
成功返回新線程句柄,失敗返回NULL,并且可調用GetLastError獲得錯誤值。

接下來我們將以兩種方式使用CreateRemoteThread,大家可以領略到CreateRemoteThread的神通,它使你的代碼可以脫離你的進程,植入到別的進程中運行。


第一種方式

第一種方式,我們使用函數的形式。即我們將自己程序中的一個函數植入到遠程進程中。

步驟1:首先在你的進程中創建函數MyFunc,我們將把它放在另一個進程中運行,這里以windows

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

步驟2:定位目標進程,這里是一個計算器
HWND hStart = ::FindWindow (TEXT("SciCalc"),NULL);

步驟3:獲得目標進程句柄,這里用到兩個不太常用的函數(當然如果經常做線程/進程等方面的 項目的話,就很面熟了),但及有用
DWORD PID, TID;
TID = ::GetWindowThreadProcessId (hStart, &PID);

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

步驟4:在目標進程中配變量地址空間,這里我們分配10個字節,并且設定為可以讀

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

PAGE_READWRITE );

步驟5:寫內容到目標進程中分配的變量空間
::WriteProcessMemory( hProcess, pDataRemote, szBuffer,(sizeof(szBuffer),NULL);

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

PAGE_EXECUTE_READWRITE );

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

步驟8:在目標進程中執行代碼

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 );
}

這里有幾個值得說明的地方:
使用WaitForSingleObject等待線程結束;
使用GetExitCodeThread獲得返回值;
最后關閉句柄CloseHandle。

步驟9:清理現場

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

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

關閉進程句柄
::CloseHandle( hProcess );

 

第二種方式

第二種方式,我們使用動態庫的形式。即我們將自己一個動態庫植入到遠程進程中。

這里不再重復上面相同的步驟,只寫出其中關鍵的地方.
關鍵1:
在步驟5中將動態庫的路徑作為變量傳入變量空間.
關鍵2:
在步驟8中,將GetProcAddress作為目標執行函數.

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


另外在步驟9,清理現場中首先要先進行釋放我們的動態庫.也即類似步驟8執行函數FreeLibrary

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

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

 


本文來自CSDN博客,轉載請標明出處:http://blog.csdn.net/fangchao918628/archive/2008/08/30/2852744.aspx

posted on 2010-09-16 14:05 深邃者 閱讀(552) 評論(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>
            99国产精品99久久久久久粉嫩| 激情久久影院| 香蕉久久夜色精品国产| 亚洲视频在线二区| 午夜精品国产精品大乳美女| 亚洲综合第一页| 性色av一区二区三区红粉影视| 欧美一级在线视频| 狼狼综合久久久久综合网| 欧美国产日产韩国视频| 欧美日韩免费在线| 国产精品网站在线观看| 在线免费观看视频一区| 中文欧美字幕免费| 欧美在线一区二区三区| 欧美成人午夜激情| 一本色道久久综合狠狠躁篇怎么玩 | 欧美在线亚洲在线| 猫咪成人在线观看| 欧美午夜精品理论片a级按摩| 国产精品一区二区久久久| 一区二区在线观看视频| 亚洲色图制服丝袜| 男男成人高潮片免费网站| 一区二区三区久久| 久久尤物视频| 国产欧美精品日韩区二区麻豆天美| 在线观看国产一区二区| 亚洲一区制服诱惑| 欧美国产三级| 欧美一区二区播放| 欧美日韩在线一区二区三区| 一区二区三区在线免费播放| 亚洲在线观看视频网站| 亚洲第一中文字幕| 欧美激情精品久久久| 亚洲免费视频成人| 欧美日韩成人一区| 亚洲国产mv| 久久精品国产视频| 一区二区三区精品视频| 欧美精品在线网站| 亚洲第一黄网| 久久久91精品国产一区二区三区| 日韩亚洲国产欧美| 美国三级日本三级久久99| 国产一区二区三区久久 | 中日韩男男gay无套| 欧美在线91| 国产精品九九久久久久久久| 亚洲国产精品电影在线观看| 久久精品国产一区二区三| 一区二区三区国产在线| 欧美日韩亚洲免费| 这里只有精品丝袜| 亚洲精品在线一区二区| 欧美好骚综合网| 亚洲欧洲综合| 亚洲电影视频在线| 欧美高清影院| 日韩视频免费| 亚洲日本va在线观看| 欧美精品午夜视频| 野花国产精品入口| 一区二区毛片| 国产精品视频| 久久精品99国产精品日本| 午夜视频在线观看一区| 国产一区欧美| 免费在线亚洲| 你懂的一区二区| 99在线|亚洲一区二区| 日韩一级不卡| 国产欧美日韩不卡| 免费永久网站黄欧美| 蜜桃久久精品一区二区| 91久久久一线二线三线品牌| 亚洲欧洲一区二区三区| 国产精品久久久久av免费| 欧美在线一级va免费观看| 久久视频一区二区| 日韩一级精品| 亚洲视频第一页| 国产午夜精品全部视频播放| 久久综合色播五月| 欧美另类videos死尸| 午夜精品av| 可以看av的网站久久看| 亚洲一区二区三区四区中文| 亚洲欧美国产日韩中文字幕| 伊人久久男人天堂| 99伊人成综合| 影院欧美亚洲| 亚洲色图制服丝袜| 在线观看欧美亚洲| 亚洲最新合集| 在线观看视频欧美| 在线视频亚洲一区| 亚洲第一网站| 亚洲女爱视频在线| 亚洲美女淫视频| 欧美中文在线观看| 亚洲制服av| 欧美成人伊人久久综合网| 欧美一区免费视频| 欧美日韩极品在线观看一区| 久久夜精品va视频免费观看| 国产精品99免费看| 亚洲高清视频中文字幕| 国产日产高清欧美一区二区三区| 欧美激情视频在线免费观看 欧美视频免费一 | 亚洲一级二级| 亚洲精品久久嫩草网站秘色 | 欧美在线亚洲在线| 欧美高清在线视频| 免费日韩一区二区| 国产毛片久久| 亚洲午夜精品一区二区三区他趣| 亚洲国产成人精品久久| 欧美专区在线观看一区| 性欧美大战久久久久久久免费观看| 欧美gay视频| 欧美波霸影院| 黄色在线一区| 久久成年人视频| 久久精品国产一区二区三区| 国产精品一区二区在线观看网站| 亚洲精品久久久蜜桃| 亚洲三级色网| 欧美成人激情视频免费观看| 免费中文字幕日韩欧美| 在线精品视频一区二区三四| 午夜精品一区二区三区在线| 亚洲欧美日韩一区在线| 欧美日韩亚洲系列| 亚洲理伦在线| 亚洲私人影院在线观看| 欧美日韩色婷婷| 99精品视频免费全部在线| 亚洲网站在线观看| 国产精品久久久久久久免费软件 | 久久精品官网| 国产在线一区二区三区四区| 欧美亚洲一级| 毛片一区二区三区| 一区二区三区在线观看欧美| 久久久久国产一区二区三区| 免费观看成人鲁鲁鲁鲁鲁视频| 曰本成人黄色| 欧美激情麻豆| 99视频有精品| 欧美在线视频免费观看| 韩国视频理论视频久久| 久久婷婷蜜乳一本欲蜜臀| 欧美69视频| 99视频精品在线| 国产精品红桃| 欧美怡红院视频| 欧美黑人一区二区三区| av成人动漫| 国产酒店精品激情| 久久久久网站| 亚洲欧洲精品一区| 午夜精品福利一区二区蜜股av| 国产日本欧洲亚洲| 免费在线国产精品| 亚洲亚洲精品三区日韩精品在线视频| 久久国产黑丝| 亚洲第一毛片| 国产日韩一区二区| 亚洲精品欧美专区| 中文在线一区| 国产精品国产三级国产普通话三级 | 韩国亚洲精品| 欧美精选在线| 亚洲欧美一区二区三区在线| 欧美不卡在线| 午夜精品亚洲一区二区三区嫩草| 激情五月***国产精品| 欧美成人免费va影院高清| 亚洲视频在线观看三级| 欧美不卡一卡二卡免费版| 午夜精品国产更新| 亚洲欧洲日产国产综合网| 国产欧美欧美| 欧美视频在线不卡| 蜜桃久久av| 久久精品系列| 午夜精品一区二区三区四区 | 快射av在线播放一区| 亚洲女人天堂成人av在线| 亚洲激情第一区| 久久亚洲免费| 欧美一区二区三区久久精品茉莉花 | 欧美精品一区在线播放| 欧美一区二区福利在线| 亚洲图片欧美午夜| 日韩视频免费观看高清完整版| 欧美 日韩 国产 一区| 久久国产精品久久久久久久久久|