【发布时间】:2021-01-30 20:47:38
【问题描述】:
我正在为一个小游戏创建一个用于教育目的的作弊(目前在 Windows 上)。到目前为止,我的错误是 ReadProcessMemory 总是读取 0。
LPCVOID addr = (LPCVOID *) 0x1228A93C; // TO-DO: c++ casts
int dest = 0;
SIZE_T read = 0;
bool error = ReadProcessMemory(process, addr, &dest, sizeof(int), &read);
if (!error) {
printf("I read %llu w/ %u at %p\r\n", read, dest, addr);
} else {
printf("This isn't working: %p / %llu\r\n", addr, read);
std::cerr << "err: " << std::to_string(::GetLastError()) << std::endl;
return (1);
}
在那里,我尝试读取游戏中的金额。通过使用作弊引擎,我得到了每次你使用钱时都会发生变化的值,即上面代码 sn-p 中的0x1228A93C。如果我在作弊引擎中更改此地址指向的值,游戏中的钱也会发生变化,所以我猜这是正确的地址。
尽管如此,当我运行这个 sn-p 时,我得到了这个输出:
I read 0 w/ 0 at 0x1228a93c
这意味着它不读取。
注意:还有更多代码,在我的程序中,在这个上面,但这基本上是找到游戏窗口,创建游戏快照并找到exe模块。
【问题讨论】:
-
请阅读
ReadProcessMemory实际返回的内容。 -
另外,
DWORD(GetLastError的返回类型)是一个无符号的 32 位整数,存在 C++ 流输出运算符<<的重载。这意味着您不需要std::to_string。 -
BOOL操作的返回值在成功时几乎总是为真,所以它应该是bool success和if (success)。 -
很可能存在访问权限问题:“句柄必须具有对进程的 PROCESS_VM_READ 访问权限。”
-
@user253751 来自我链接到的参考:
BOOL ReadProcessMemory(...)。所以是的,它返回一个BOOL,其中TRUE是成功的。
标签: c++ windows winapi memory reverse-engineering