龙马谷

 找回密码
 立即注册

QQ登录

只需一步,快速开始

龙马谷VIP会员办理客服QQ:82926983(如果临时会话没有收到回复,请先加QQ好友再发。)
1 [已完结] GG修改器新手入门与实战教程 31课 2 [已完结] GG修改器美化修改教程 6课 3 [已完结] GG修改器Lua脚本新手入门教程 12课
4 [已完结] 触动精灵脚本新手入门必学教程 22课 5 [已完结] 手游自动化脚本入门实战教程 9课 6 [已完结] C++射击游戏方框骨骼透视与自瞄教程 27课
7 [已完结] C++零基础UE4逆向开发FPS透视自瞄教程 29课 8 [已完结] C++零基础大漠模拟器手游自动化辅助教程 22课 9 [已完结] C++零基础开发DXF内存脚本辅助教程 32课
以下是天马阁VIP教程,本站与天马阁合作,赞助VIP可以获得天马阁对应VIP会员,名额有限! 点击进入天马阁论坛
1 [已完结] x64CE与x64dbg入门基础教程 7课 2 [已完结] x64汇编语言基础教程 16课 3 [已完结] x64辅助入门基础教程 9课
4 [已完结] C++x64内存辅助实战技术教程 149课 5 [已完结] C++x64内存检测与过检测技术教程 10课 6 [已完结] C+x64二叉树分析遍历与LUA自动登陆教程 19课
7 [已完结] C++BT功能原理与x64实战教程 29课 8 [已完结] C+FPS框透视与自瞄x64实现原理及防护思路
查看: 8091|回复: 0

Anti内存修改 内存WriteWatch跟踪技术

[复制链接]

14

主题

0

回帖

18

积分

编程入门

Rank: 1

龙马币
38
三月的天气 | 显示全部楼层 |阅读模式
原理:
微软提供的内存WriteWatch跟踪技术,
对于申请为MEM_WRITE_WATCH的内存,
可以监控内存变更(包括外界变更)。

举例代码:仅仅是举个例子
  1. #include <windows.h>
  2. #include <stdio.h>

  3. typedef struct _POSITION_
  4. {
  5.     DWORD dx;
  6.     DWORD dz;
  7.     DWORD dy;
  8. }POSITION,*PPOSITION;

  9. #define BASE_SIZE 0x1000
  10. #define WALK_ADD 10
  11. DWORD WINAPI WatchThread(LPVOID Param)
  12. {
  13.     ULONG size = 0;
  14.     DWORD p = 0;
  15.     UINT  Ret = 0;
  16.     PVOID px[0x400] = { 0 };
  17.     while (1)
  18.     {
  19.         size = 0x400;
  20.         p = 0;
  21.         Ret = GetWriteWatch(WRITE_WATCH_FLAG_RESET, Param, BASE_SIZE, px, &size, &p);
  22.         if (Ret == 0
  23.             && size != 0)
  24.         {
  25.             MessageBoxW(NULL, L"发现第三方软件修改关键内存", L"发现第三方软件", MB_OK);
  26.         }
  27.     }
  28.     return 0;
  29. }
  30. int __cdecl main(int argc, char *argv[])
  31. {
  32.     //申请Base基址内存
  33.     PVOID Base = VirtualAlloc(NULL, BASE_SIZE, MEM_RESERVE | MEM_COMMIT | MEM_WRITE_WATCH, PAGE_READWRITE);
  34.     PPOSITION pos = (PPOSITION)Base;
  35.     //初始化坐标
  36.     pos->dx = pos->dy = pos->dz = 1000;
  37.     //清空监控记录
  38.     ResetWriteWatch(Base, BASE_SIZE);
  39.     //开启监控线程
  40.     HANDLE hThread = CreateThread(NULL, 0, WatchThread, Base, 0, NULL);
  41.     while (1)
  42.     {
  43.         //暂停监控线程
  44.         SuspendThread(hThread);//也可以通过其他方式进行!!!!暂停线程只是简单模型
  45.         //模拟走路过程
  46.         pos->dx += WALK_ADD;
  47.         //继续监控
  48.         ResetWriteWatch(Base, BASE_SIZE);
  49.         ResumeThread(hThread);
  50.         //输出X坐标
  51.         printf("x = %d\n", pos->dx);
  52.         Sleep(1000);
  53.     }
  54.     return 0;
  55. }
复制代码

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

龙马谷| C/C++辅助教程| 安卓逆向安全| 论坛导航| 免责申明|Archiver|
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表龙马谷立场!
任何人不得以任何方式翻录、盗版或出售本站视频,一经发现我们将追究其相关责任!
我们一直在努力成为最好的编程论坛!
Copyright© 2018-2021 All Right Reserved.
在线客服
快速回复 返回顶部 返回列表