【Windows 逆向】使用 CE 工具挖掘关键数据内存真实地址 ( 数据查找技巧

【Windows 逆向】使用 CE 工具挖掘关键数据内存真实地址 ( 数据查找技巧

文章目录一、查找动态地址二、静态地址查找技巧1、地址访问调试2、指令选择技巧3、MOV 汇编指令含义4、基址值搜索一、查找动态地址以查找子弹数量内存为例 , 参考 【Windows 逆向】使用 CE 工具挖掘关键数据内存真实地址 ( 查找子弹数据的动态地址 | 查找子弹数据的静态地址 | 静态地址分析 | 完整流程 ) ★ 一、查找子弹数据临时内存地址 博客章节 ;

首先 , 查找到子弹数据的 动态地址 05A59544 , 该步骤很容易 , 多次扫描内存 , 最后使用二分法 , 逐步找到最终的内存地址 ;

然后 , 就是根据 动态地址 05A59544 , 查找到该动态地址是如何计算出来的 ;

二、静态地址查找技巧根据动态地址 , 查找对应的静态地址 , 以及 寻址 , 偏移 过程 ;

1、地址访问调试右键点击该地址 , 选择 " 找出是什么访问了这个地址 F5 " 选项 , 就可以对该地址进行调试 , 查询哪个指令为该地址进行了赋值操作 , 也就是 子弹的个数 int 类型数据 是怎么写进去的 ;

也可以左键点击 , 选中该地址 , 直接按 F5 快捷键 ,

此时 , 可以查询 , 哪些汇编指令 , 访问了 子弹数据的 动态地址 05A59544 ;

2、指令选择技巧选择指令的技巧 : 选择指令时 , 不会任意选择的 , 而是有一定的技巧 ;

优先选择

代码语言:javascript复制MOV 寄存器 , [寄存器 + 立即数]格式的指令 , 进行基址查询 ;

在上述类型的指令中 , 优先选择

代码语言:javascript复制MOV EAX , [寄存器 + 立即数]样式的指令 , 大部分游戏中的寄存器都是使用的 EAX 寄存器 ;

第一条指令 , 就符合上述要求 , 那么展开分析第一条指令 ;

代码语言:javascript复制指针基址可能是 =05A59478

05C1C0ED - mov eax,[esi+000000CC]代码语言:javascript复制EAX=00000050

EBX=0E1DBB70

ECX=00000000

EDX=00000001

ESI=05A59478

EDI=00000001

EBP=00000000

ESP=0019F2F0

EIP=05C1C0F3

指针基址可能是 =05A59478

05C1C0E6 - je mp.CBasePlayerItem::DestroyItem+20D

05C1C0E8 - mov ecx,00000001

05C1C0ED - mov eax,[esi+000000CC]

05C1C0F3 - mov edx,[esi+000000D0]

05C1C0F9 - cmp eax,edx3、MOV 汇编指令含义MOV 指令格式 : 将 SRC 数值,写入到 DST 位置 ;

代码语言:javascript复制MOV DST,SRCmov eax,[esi+000000CC] 汇编代码和含义 :

[esi+000000CC] 是 基址变址寻址 , 取出 esi 寄存器的值 05A59478 , 与 CC 相加 , 得到一个地址 05A59544 , 这个地址就是子弹数据的地址 , 读取该地址中的值 , 写入到 EAX 寄存器中 ;

从上述汇编代码中 , 可以知道 , 子弹数据的动态地址 05A59544 , 是由 基址 05A59478 加上立即数 CC 得来的 ;

4、基址值搜索那么基址 05A59478 又是如何得来的呢 ;

搜索 基址值 所在内存位置 : 那么后续在整个内存中 , 搜索这个基址 05A59478 值 , 查询该值所在的地址 ;

F5 调试 基址值 如何计算得到的 : 然后查询该地址的值是哪条汇编指令计算出来的 , 需要使用 F5 调试 , 选择一条汇编指令进行分析 , 汇编指令选择方法 : 优先选择 MOV EAX , [寄存器 + 立即数] 样式的汇编指令 ;

相关推荐

YSL方管or圆管哪个好 如何选择合适自己的YSL口红
[交流]大话2与大话3的区别
串串香制作指南:如何在家自制美味串串香?
战地一为什么被服务器停用
《dnf》110版本打深渊位置一览
漂染头发需要多长时间 给头发褪色要多久
李治被误解千年,真实的李治究竟有多恐怖?看看外国如何评价他的
优质qq千人群怎么创建

优质qq千人群怎么创建

08-13 👁️ 4265
怎么查看QQ亲密度

怎么查看QQ亲密度

08-04 👁️ 3307