远程线程DLL注入

在其他进程中,创建一个新的线程来LoadLibraryA我们的Dll。

 

/*作者:sysprogram
   编写日期:2011年4月2日
   博客:http://hi.youkuaiyun.com/SysProgram

*/

 

#include <windows.h>
#include <stdio.h>

void main()
{
 //打开进程句柄
 HANDLE hProcess;
 hProcess = OpenProcess(PROCESS_ALL_ACCESS,false,1956);
 if (hProcess == NULL)
 {  
  printf("Open Process error/n");
  return;
 }

 //给进程分配内存
 LPVOID BaseAddress; 
 char *strDllName = {"C://dlltest.dll"};
 int len = strlen(strDllName) + 1;
 BaseAddress = VirtualAllocEx(hProcess,NULL,len,MEM_COMMIT,PAGE_READWRITE);
 
 //写进程内存
 if (WriteProcessMemory(hProcess,BaseAddress,strDllName,len,NULL) == false)
 {
  printf("Write Memory error/n");
  return;
 }

 //创建远程线程
 FARPROC ProcAddress;
 HMODULE hModule = GetModuleHandle("Kernel32.dll");
 ProcAddress = GetProcAddress(hModule,"LoadLibraryA");

 HANDLE hThread;
 hThread = CreateRemoteThread(hProcess,
        NULL,
        0,
        (LPTHREAD_START_ROUTINE)ProcAddress,
        BaseAddress,
        0,
        NULL);

 //等待线程完成
 WaitForSingleObject(hThread,INFINITE);
 
 //释放内存,关闭句柄
 VirtualFreeEx(hProcess,BaseAddress,0,MEM_RELEASE); 
 CloseHandle(hThread);
 CloseHandle(hProcess);

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值