X86 X64远程线程注入

#include <Windows.h>
#include <stdio.h>
#include <iostream>
using namespace std;

BOOL 远程注入(DWORD ProcessID, string DllRoad)
{
//打开进程句柄
HANDLE ProcessHandle = OpenProcess(PROCESS_ALL_ACCESS, FALSE, ProcessID);

LONG64 RoadLength = (DllRoad.length() + 1) * 2;
//申请一段内存存放路径地址
PVOID 申请内存地址 = VirtualAllocEx(ProcessHandle, NULL, RoadLength, MEM_COMMIT, PAGE_READWRITE);
if (申请内存地址 == NULL)
{
    MessageBoxA(0, "申请内存地址失败", "申请内存地址失败",0);
    return false;
}


bool ret = WriteProcessMemory(ProcessHandle, (PCHAR)申请内存地址, DllRoad.c_str(), RoadLength, NULL);
if (ret == NULL)
{
    VirtualFreeEx(ProcessHandle, 申请内存地址, 0, MEM_RELEASE);
    CloseHandle(ProcessHandle);
    MessageBoxA(0, "写入路径内存失败", "写入路径内存失败", 0);
    return false;
}

//远程线程注入
HANDLE RemoteThreadHandle = CreateRemoteThread(ProcessHandle, NULL, 0, (LPTHREAD_START_ROUTINE)LoadLibraryA, 申请内存地址, 0, 0);
if (RemoteThreadHandle == NULL)
{
    VirtualFreeEx(ProcessHandle, 申请内存地址, 0, MEM_RELEASE);
    CloseHandle(ProcessHandle);
    MessageBoxA(0, "创建远程线程失败", "创建远程线程失败", 0);
    return false;
}
//dwMilliseconds[in]定时时间间隔,单位为milliseconds(毫秒).如果指定一个非零值,函数处于等待状态直到hHandle标记的对象被触发,或者时间到了。如果dwMilliseconds为0,对象没有被触发信号,函数不会进入一个等待状态,它总是立即返回。如果dwMilliseconds为INFINITE,对象被触发信号后,函数才会返回。
WaitForSingleObject(RemoteThreadHandle, INFINITE);

Sleep(1000);
//释放申请内存   关闭句柄
VirtualFreeEx(ProcessHandle, 申请内存地址, 0, MEM_RELEASE);
CloseHandle(ProcessHandle);
CloseHandle(RemoteThreadHandle);

return true;

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值