在C++中,WriteProcessMemory函數用于向指定進程的內存寫入數據。
函數的用法如下:
BOOL WriteProcessMemory(
HANDLE hProcess, // 目標進程的句柄
LPVOID lpBaseAddress, // 寫入數據的起始地址
LPCVOID lpBuffer, // 數據緩沖區的指針
SIZE_T nSize, // 要寫入的字節數
SIZE_T *lpNumberOfBytesWritten // 實際寫入的字節數
);
參數說明:
hProcess
:目標進程的句柄,可以通過OpenProcess函數獲得。lpBaseAddress
:寫入數據的起始地址。lpBuffer
:指向要寫入的數據的緩沖區指針。nSize
:要寫入的字節數。lpNumberOfBytesWritten
:指向一個變量的指針,用于存儲實際寫入的字節數。函數返回值:
示例代碼:
#include <iostream>
#include <windows.h>
int main()
{
// 打開目標進程
HANDLE hProcess = OpenProcess(PROCESS_ALL_ACCESS, FALSE, targetProcessId);
// 寫入數據
int value = 123;
LPVOID lpBaseAddress = (LPVOID)0x12345678;
SIZE_T nSize = sizeof(value);
SIZE_T lpNumberOfBytesWritten;
BOOL result = WriteProcessMemory(hProcess, lpBaseAddress, &value, nSize, &lpNumberOfBytesWritten);
if (result)
{
std::cout << "WriteProcessMemory succeeded. Bytes written: " << lpNumberOfBytesWritten << std::endl;
}
else
{
std::cout << "WriteProcessMemory failed. Error code: " << GetLastError() << std::endl;
}
// 關閉目標進程句柄
CloseHandle(hProcess);
return 0;
}
上述示例代碼中,首先使用OpenProcess函數打開了一個目標進程的句柄。然后通過WriteProcessMemory函數向目標進程寫入了一個整數值。最后使用CloseHandle函數關閉目標進程句柄。