龙马谷

 找回密码
 立即注册

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课
以下是天马阁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实现原理及防护思路
查看: 1115|回复: 2

模仿Cheat Engine内存搜索--Sunday算法

[复制链接]

11

主题

11

回帖

25

积分

编程入门

Rank: 1

龙马币
32
小子不忘记 | 显示全部楼层 |阅读模式

想要获取一个进程里面的某个数据,需要先知道这个数据的位置
对于全局变量:偏移是固定的,可以通过“基址+偏移”直接定位
对于局部变量:位置是随机的,只能通过拦截或者搜索去定位

分析企业微信的时候,发现很多数据都不是全局变量,不能像个人微信那样直接跨进程读取。
如果能够用代码模仿Cheat Engine进行内存搜索,就可以定位到局部变量,进而实现非注入读取。甚至可以做到兼容所有版本(比如登录二维码,直接内存扫描出来)。
  
Cheat Engine是开源的,下面是特征码搜索的源码:
  1. DWORD AOBScan(HANDLE hProcess, const char* pattern, const char* mask, uint64_t start, uint64_t end, int inc, int protection,uint64_t * match_addr)
  2. {
  3.     // 查询内存块信息,看下是不是可读可写可执行
  4.     VirtualQueryEx(hProcess, (void*)tmp, &rinfo, NULL);
  5.     if((rinfo.protection & protection) != 0) ...

  6.     // 读取内存,用暴力算法BF(Brute Force)算法进行字符匹配
  7.     ReadProcessMemory(hProcess, (void*)tmp2, MemoryBuff, 4096)
  8.     for (int i = 0; i < 4096; i += inc)
  9.         for (int k = 0; k < patternLength; k++)
  10.             if (!(mask[k] == '?' || pattern[k] == (MemoryBuff[k])))
  11. }
复制代码


游客,如果您要查看本帖隐藏内容请回复


0

主题

9

回帖

14

积分

编程入门

Rank: 1

龙马币
50
qq1637516375 | 显示全部楼层
仿Cheat Engine内存搜索--Sunday算法

0

主题

23

回帖

24

积分

编程入门

Rank: 1

龙马币
10
longmaguniuma | 显示全部楼层
看看源码
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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