DLL注入之远程线程注入

WCHAR szDllName[] = L"/*要注入的dll的路径*/";

	if(szDllName[0] == NULL)
		return -1;
	// 1、打开进程
	HANDLE hProcess = OpenProcess(PROCESS_ALL_ACCESS, FALSE, /*进程PID*/);

	if(hProcess == INVALID_HANDLE_VALUE)
		return -1;
	// 2、在远程进程中申请空间
	LPVOID pszDllName = VirtualAllocEx(hProcess, NULL, 4096, MEM_COMMIT, PAGE_EXECUTE_READWRITE);
	if(NULL == pszDllName)
		return -1;
	// 3、向远程进程中写入数据
	if(!WriteProcessMemory(hProcess, pszDllName, szDllName, MAX_PATH, NULL))
		return -1;
	// 4、在远程进程中创建远程进程
	HANDLE hInjectthread = CreateRemoteThread(hProcess,
		NULL, 
		0,
		(LPTHREAD_START_ROUTINE)LoadLibrary,
		pszDllName,
		NULL,
		NULL);
	if(NULL == hInjectthread)
		return -1;
	// 5、等待线程结束返回
	DWORD dw = WaitForSingleObject(hInjectthread, -1);
	// 6、获取线程退出码, 即LoadLibrary 的返回值 DLl的首地址
	DWORD dwExitCode;
	GetExitCodeThread(hInjectthread, &dwExitCode);
	HMODULE hMod = (HMODULE)dwExitCode;
	// 7、释放空间
	if(!VirtualFreeEx(hProcess, pszDllName, 4096, MEM_DECOMMIT))
		return -1;
	CloseHandle(hProcess);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值