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

S.l.e!ep.¢%

像打了激速一樣,以四倍的速度運轉(zhuǎn),開心的工作
簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
posts - 1098, comments - 335, trackbacks - 0, articles - 1
  C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

CreateRemoteThread-實現(xiàn)進程代碼注入

Posted on 2010-02-05 21:33 S.l.e!ep.¢% 閱讀(2495) 評論(0)  編輯 收藏 引用 所屬分類: RootKit
CreateRemoteThread-實現(xiàn)進程代碼注入
2008年12月27日 星期六 00:19

起因:哇卡卡同學(xué)昨天叫我?guī)退匆粋€進程代碼注入的程序問題,運行到CreateRemoteThread就出錯,由于之前沒做過這種事情看了一下他寫的代碼大體上就明白怎么做了,于是自己重新又做了一個,遇到多少艱辛就不說了,不過讓我有種寫shellcode的感覺:-D,自己run一次才是自己的東西嘛.

方法很多種,下面只是介紹其中的一種而已.

大體思路:首先明確目標(biāo)在NOTEPAD.EXE中彈出MessageBox.現(xiàn)在系統(tǒng)中找出NOTEPAD.EXE進程,兩次用VirtualAllocExNOTEPAD.EXE進程聲明一塊可讀寫運行的內(nèi)存塊,WriteProcessMemory寫入我們代碼注入的線程函數(shù)和傳給線程函數(shù)的參數(shù),最后運用CreateRemoteThread,變可讓我們之前寫入的線程函數(shù)運行.

技巧一:我們這里使用形如下面的形式來計算需要寫入函數(shù)的大小:

#pragma check_stack (off)

static DWORD WINAPI ThreadProc (LPVOID lpParameter){}

static void AfterThreadProc (void) { }

#pragma check_stack

DWORD cbCodeSize = (BYTE*)AfterThreadProc - (BYTE*)ThreadProc;


技巧二:我們這里聲明一個HYPINJECT結(jié)構(gòu),里面存放一些函數(shù)的地址,然后傳遞給線程函數(shù),不然直接在線程函數(shù)里面寫Win 32 API函數(shù),可能導(dǎo)致崩潰.結(jié)構(gòu)如下:

typedef struct tagHYPINJECT {

?????? ProcLoadLibrary??? fnLoad;

?????? ProcGetProcAddress fnGetProc;

?????? char MsgStr [MAX_PATH];

?????? char DLLName [MAX_PATH];

?????? char ProcName [MAX_PATH];

} HYPINJECT;

關(guān)于編寫線程函數(shù)的注意事項: (自己總結(jié)加網(wǎng)上資料)

線程函數(shù)里面最好不要調(diào)用除Kernel32User32以外的所有函數(shù),貌似User32里面的部分函數(shù)在調(diào)用的時候也會出現(xiàn)崩潰的局面,如果要調(diào)用其他庫的函數(shù)可以把LoadLibraryGetProcAddress的地址當(dāng)作線程函數(shù)的參數(shù)傳過去(下面的代碼就是這么實現(xiàn)的),不過如果已知某動態(tài)鏈接庫已經(jīng)加載了,最好還是使用GetModuleHandle取代LoadLibrary.當(dāng)然如果你想調(diào)用自己寫的函數(shù)的話也要把函數(shù)代碼復(fù)制到目標(biāo)進程里面去,然后把地址通過線程函數(shù)的參數(shù)傳過去.

而且不要使用任何的靜態(tài)字符串,線程函數(shù)最好寫成靜態(tài)(貌似也可以直接禁止 增量鏈接 ), 函數(shù)和變量之類大小也不要太大不然可能在VirtualAllocEx的時候就不能成功

……

全部代碼如下:

#include <windows.h>

#include <Tlhelp32.h.>


typedef HINSTANCE (WINAPI *ProcLoadLibrary)(char*);

typedef FARPROC (WINAPI *ProcGetProcAddress)(HMODULE, LPCSTR);

typedef int (WINAPI *ProcMessageBox)(HWND,LPCTSTR,LPCTSTR,UINT);

typedef struct tagHYPINJECT {

?????? ProcLoadLibrary??? fnLoad;

?????? ProcGetProcAddress fnGetProc;

?????? char MsgStr [MAX_PATH];

?????? char DLLName [MAX_PATH];

?????? char ProcName [MAX_PATH];

} HYPINJECT;

#pragma check_stack (off)

static DWORD WINAPI ThreadProc (LPVOID lpParameter)

{

?????? HYPINJECT* p = (HYPINJECT*)lpParameter;

?????? HMODULE hDLL = p->fnLoad (p->DLLName);

??? ProcGetProcAddress GetProc = p->fnGetProc;

?????? ProcMessageBox MsgBox = (ProcMessageBox)GetProc(hDLL,p->ProcName);

??? MsgBox(NULL,p->MsgStr,p->MsgStr,MB_OK);

?????? return 0;

}

static void AfterThreadProc (void) { }

#pragma check_stack


HYPINJECT hypInject;


BOOL InjectFunc(DWORD PID)

{

?????? HMODULE hk = LoadLibrary ("kernel32.dll");

?????? hypInject.fnLoad = (ProcLoadLibrary)GetProcAddress (hk, "LoadLibraryA");

?????? hypInject.fnGetProc = (ProcGetProcAddress)GetProcAddress (hk, "GetProcAddress");

?????? strcpy(hypInject.MsgStr," hyp's Knowledge Base");

?????? strcpy (hypInject.DLLName, "user32.dll");

?????? strcpy (hypInject.ProcName, "MessageBoxA");


?????? PVOID pCode = NULL;

?????? PVOID pData = NULL;

?????? BOOL bc = FALSE;

?????? DWORD cbCodeSize = (BYTE*)AfterThreadProc - (BYTE*)ThreadProc;


?????? HANDLE hProc = OpenProcess(

????????????? PROCESS_QUERY_INFORMATION |??

????????????? PROCESS_CREATE_THREAD???? |

????????????? PROCESS_VM_OPERATION????? |

????????????? PROCESS_VM_WRITE,???????????

????????????? FALSE, PID);

?????? if (hProc == NULL)

?????? {

????????????? return FALSE;

?????? }

??????

?????? pCode=VirtualAllocEx(hProc,NULL,cbCodeSize,MEM_COMMIT,PAGE_EXECUTE_READWRITE);

?????? if(pCode == NULL)

?????? {

????????????? return FALSE;

?????? }

?????? bc = WriteProcessMemory(hProc,pCode,(LPVOID)(DWORD) ThreadProc,cbCodeSize,NULL);

?????? if (!bc)

?????? {

????????????? return FALSE;

?????? }


?????? pData = VirtualAllocEx (hProc,NULL, sizeof (hypInject), MEM_COMMIT, PAGE_EXECUTE_READWRITE);

?????? if(pData == NULL)

?????? {

????????????? return FALSE;

?????? }

?????? bc = WriteProcessMemory (hProc, pData, &hypInject, sizeof (hypInject), NULL);

?????? if (!bc)

?????? {

????????????? return FALSE;

?????? }


?????? HANDLE ht=CreateRemoteThread(hProc,NULL,NULL,(LPTHREAD_START_ROUTINE)pCode,pData,0,NULL);

?????? if(ht == NULL)

?????? {

????????????? return FALSE;

?????? }

?????? CloseHandle(hProc);

?????? return TRUE;

}


int main()

{

?????? HANDLE hSnapshot = NULL;

?????? hSnapshot=CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS,NULL);

?????? PROCESSENTRY32 pe;

?????? pe.dwSize = sizeof(PROCESSENTRY32);

?????? Process32First(hSnapshot,&pe);

?????? do

?????? {

????????????? if(stricmp(pe.szExeFile,"NOTEPAD.EXE")==0)

????????????? {

???????????????????? InjectFunc(pe.th32ProcessID);

???????????????????? break;

????????????? }

?????? }

?????? while(Process32Next(hSnapshot,&pe)==TRUE);

?????? CloseHandle (hSnapshot);????

?????? 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综合亚洲精品ⅰ| 亚洲精品社区| 雨宫琴音一区二区在线| 亚洲一区一卡| 亚洲午夜在线观看| 欧美电影免费观看高清| 久久综合伊人77777尤物| 国产精品久久二区二区| 亚洲精品视频在线播放| 最新亚洲视频| 久久一区二区三区av| 久久视频在线视频| 国产婷婷精品| 亚洲欧美日韩综合国产aⅴ| 亚洲一区区二区| 欧美日韩精品一区二区三区四区| 久久人人爽人人爽| 国产又爽又黄的激情精品视频| 亚洲在线视频观看| 亚洲女人av| 国产精品羞羞答答xxdd| 中文在线一区| 午夜精品av| 国产精品亚洲人在线观看| 亚洲视频在线一区观看| 亚洲一区二区免费看| 欧美日韩一级视频| 中文在线不卡| 久久国产欧美精品| 黄色成人av网| 久久久欧美一区二区| 欧美国产日韩一区二区| 亚洲精品美女在线观看| 欧美日韩国产小视频| 亚洲香蕉视频| 久久精品一区二区三区不卡牛牛| 国产一区亚洲| 麻豆精品一区二区综合av| 亚洲国产视频直播| 一区二区免费在线观看| 国产精品久久久久久亚洲毛片 | 最新国产乱人伦偷精品免费网站| 亚洲精品女av网站| 国产精品theporn88| 午夜国产精品视频| 久久在线视频在线| 91久久精品国产91久久性色| 欧美日韩国产免费观看| 亚洲影视综合| 欧美大片免费观看| av成人激情| 国产日韩精品一区二区三区在线| 久久www免费人成看片高清| 欧美激情91| 午夜精品亚洲一区二区三区嫩草| 狠狠色狠狠色综合日日五| 欧美jizzhd精品欧美喷水| aⅴ色国产欧美| 老司机午夜精品| 国产精品99久久久久久久女警| 国产欧美日韩| 欧美精品日日鲁夜夜添| 午夜精品亚洲一区二区三区嫩草| 亚洲黄页视频免费观看| 久久国产精品亚洲77777| 亚洲日本va在线观看| 国产麻豆精品在线观看| 欧美不卡视频一区| 欧美一级播放| 日韩视频一区二区三区在线播放免费观看| 欧美一区二区高清| 一区二区三区成人精品| 在线成人av网站| 国产乱子伦一区二区三区国色天香| 麻豆精品视频在线观看视频| 亚洲欧美日韩在线一区| 亚洲精品视频在线观看网站 | 亚洲激情视频网站| 久久九九国产| 亚洲专区在线视频| 日韩午夜电影av| 亚洲电影免费在线观看| 国产亚洲网站| 国产精品美女久久久浪潮软件| 欧美成人精品激情在线观看| 久久国内精品视频| 亚洲一区国产精品| 99在线热播精品免费| 亚洲激情电影中文字幕| 免费试看一区| 久久婷婷国产麻豆91天堂| 午夜精品久久久久久久久| 日韩亚洲一区在线播放| 最新中文字幕一区二区三区| 精品成人国产| 国内精品视频一区| 国产一区二区你懂的| 国产色产综合产在线视频| 国产精品久久久久高潮| 国产精品福利久久久| 欧美网站在线观看| 欧美日韩在线播放三区四区| 欧美日韩免费一区二区三区视频 | 91久久精品国产| 亚洲高清视频一区| 亚洲第一精品影视| 亚洲韩国日本中文字幕| 亚洲成人资源| 欧美性事免费在线观看| 欧美日韩免费网站| 欧美日韩妖精视频| 国产精品久久一级| 国产精品视区| 国产亚洲欧美日韩精品| 国外成人在线视频网站| 在线观看福利一区| 亚洲国产高清自拍| 日韩午夜电影av| 亚洲永久视频| 久久精品天堂| 美女主播精品视频一二三四| 亚洲大胆在线| 亚洲免费观看| 亚洲女同在线| 久久久久成人精品| 欧美国产欧美亚洲国产日韩mv天天看完整| 欧美大片国产精品| 国产精品v日韩精品| 国产亚洲女人久久久久毛片| 在线欧美日韩国产| 一个人看的www久久| 欧美一级久久久| 欧美成人午夜激情| 一区二区三区精品久久久| 欧美一级大片在线观看| 母乳一区在线观看| 国产精品久久久久av免费| 激情综合自拍| 正在播放亚洲一区| 久久人91精品久久久久久不卡| 亚洲国产日韩欧美| 亚洲欧美电影院| 欧美aⅴ一区二区三区视频| 国产精品久久久久秋霞鲁丝| 一区二区在线看| 亚洲线精品一区二区三区八戒| 久久大逼视频| 亚洲精品中文在线| 久久激情视频| 欧美性色综合| 亚洲三级毛片| 欧美中文在线观看国产| 亚洲精品乱码久久久久久| 久久国产一区| 国产精品色婷婷久久58| 91久久极品少妇xxxxⅹ软件| 欧美一区日本一区韩国一区| 91久久国产自产拍夜夜嗨| 欧美一区二区性| 欧美日韩一区二区三区免费看| 极品尤物一区二区三区| 亚洲男人的天堂在线| 91久久精品日日躁夜夜躁国产| 香蕉久久a毛片| 国产精品国产三级国产aⅴ入口| 在线成人国产| 久久九九久精品国产免费直播| 亚洲人成欧美中文字幕| 久久躁狠狠躁夜夜爽| 国产欧美一区二区精品性色| 亚洲午夜高清视频| 亚洲国产精品电影在线观看| 久久人人97超碰国产公开结果| 国产精品视频导航| 亚洲视频香蕉人妖| 亚洲国产综合在线看不卡| 久久综合色天天久久综合图片| 国产亚洲福利社区一区| 亚洲欧洲av一区二区三区久久| 亚洲精品国产无天堂网2021| 免费视频一区| 亚洲欧洲另类国产综合| 能在线观看的日韩av| 久久久久久久性| 激情综合久久| 美女精品在线观看| 久久精品人人做人人综合| 国产一区二区精品在线观看| 久久av一区二区三区| 亚洲女ⅴideoshd黑人| 国产精品毛片a∨一区二区三区|国| 一区二区三区视频免费在线观看| 亚洲国产精品一区二区尤物区| 久久亚洲国产成人| 亚洲欧洲日本国产| 亚洲国产视频直播| 欧美日韩亚洲在线| 午夜亚洲性色视频| 欧美一区二视频|