破解另一个图书馆的内存
Hacking the memory of another library
我正试图启动或访问扫雷舰实例,以便根据需要挂起并调用它的函数,以发挥作用并创建解算器。我尝试了两种方法:用它启动一个进程,并用网上找到的方法在其中注入我的dll。两者最终都遇到了相同的问题:当我从我的程序或注入的库访问扫雷舰库的内存时,我得到了错误998。你建议我做什么?我对Windows API不太了解,所以我不知道问题是否出在我使用的方法上,或者我是否必须进行一些额外的函数调用或更改一些设置。
您的问题很可能是您试图在不更改页面保护的情况下写入目标的内存。可执行页面通常是只读的(也是可执行的)。您需要使用VirtualProtect来更改此保护。通常,这类代码会被执行:
DWORD flOldProtect;
VirtualProtect((LPVOID)from, 5, PAGE_EXECUTE_READWRITE, &flOldProtect);
...
VirtualProtect((LPVOID)from, 5, flOldProtect, &flOldProtect);
此代码更改保护,以便您可以对其进行写入。您可以在...
中执行挂钩代码等,然后恢复页面保护。这是我不久前为某人写的一个非常基本的训练器,它通过DLL注入工作。
相关文章:
- 将字符串存储在c++中的稳定内存中
- C++ 指针的内存地址和指向数组的内存地址如何相同?
- Win32编译器选项和内存分配
- 当vector是tje全局变量时,c++中vector的内存管理
- 带内存和隔离功能的SQLite
- 是否可以通过C++扩展强制多个python进程共享同一内存
- 迭代时从向量和内存中删除对象
- 在C++中打印指向不同基元数据类型的指针的内存地址
- 这个指针和内存代码打印是什么?我不知道是打印垃圾还是如何打印我需要的值
- 多个文件的内存分配错误"在抛出 'std :: bad_alloc' what (): std :: bad_alloc 的实例后终止调用" [C++]
- 为什么示例代码访问IUnknown中已删除的内存
- 如何在C++类内存结构中创建"spacer"?
- 从构造函数抛出异常时如何克服内存泄漏
- malloc() 可能出现内存泄漏
- 如何理解将半精度指针转换为无符号长指针和相关的内存对齐
- 在调用FreeLibrary后,释放动态链接到具有相同版本的CRT堆的DLL的内存
- 如何针对特定情况调试和修复此双自由内存损坏问题
- 类型总是使用其大小存储在内存中吗
- 有没有一种方法可以测量c++程序的运行时内存使用情况
- 破解另一个图书馆的内存