先解释一下远程进程,其实就是要植入你的代码的进程,相对于你的工作进程(如果叫本地进程的话)它就叫远程进程,可理解为宿主。 .KT+,Y
AEnS_Q
首先介绍一下我们的主要工具CreateRemoteThread,这里先将函数原型简单介绍以下。 2>O2#53ls0
J6 [x(T
CreateRemoteThread可将线程创建在远程进程中。 [`fq4Ky
gqD`1/
函数原型 P+3G*M=}
HANDLE CreateRemoteThread( }C7tlA8,7
HANDLE hProcess, // handle to process s80_e
LPSECURITY_ATTRIBUTES lpThreadAttributes, // SD #s#z@F
SIZE_T dwStackSize, // initial stack size G-3.-
LPTHREAD_START_ROUTINE lpStartAddress, // thread function #K!Df%,<
LPVOID lpParameter, // thread argument pLzsL>6h
DWORD dwCreationFlags, // creation option &,."=G
LPDWORD lpThreadId // thread identifier ?GFxJ6!%I
); OqBw&zm
参数说明: y=vH8D]%X
hProcess e^Xij Id.
[输入] 进程句柄 AD?DIE(v
lpThreadAttributes 7^iF,N
[输入] 线程安全描述字,指向SECURITY_ATTRIBUTES结构的指针 6ddkUPTF
dwStackSize NTL#!
[输入] 线程栈大小,以字节表示 BQS9q'u_
lpStartAddress .4!N#'
[输入] 一个LPTHREAD_START_ROUTINE类型的指针,指向在远程进程中执行的函数地址 sjTsaM;<
lpParameter $xu?zd"
[输入] 传入参数 ;wQWt_OtuJ
dwCreationFlags ;mi0Q.
[输入] 创建线程的其它标志 _;B!6cRLps
N@MeaO
lpThreadId N0vd>b
[输出] 线程身份标志,如果为NULL,则不返回 ;7`<.y
g=Qga09
返回值 -Ez|
成功返回新线程句柄,失败返回NULL,并且可调用GetLastError获得错误值。 f6L_uk`{
w ^<Y5K
接下来我们将以两种方式使用CreateRemoteThread,大家可以领略到CreateRemoteThread的神通,它使你的代码可以脱离你的进程,植入到别的进程中运行。 {yb\p9q{Yo
YRp\#pVnZ
第一种方式,我们使用函数的形式。即我们将自己程序中的一个函数植入到远程进程中。 9x?;;qC"m9
K%=n \Y
步骤1:首先在你的进程中创建函数MyFunc,我们将把它放在另一个进程中运行,这里以windows }=;>T)QmMO
{my=Li<