6.第二阶段x64游戏实战-分析人物状态

免责声明:内容仅供学习参考,请合法利用知识,禁止进行违法犯罪活动!

本次游戏没法给

内容参考于:微尘网络安全

上一个内容:5.第二阶段x64游戏实战-动态模块地址

人物状态是与角色相关的,如果做辅助的话是需要判断当前人物是在打怪中还是移动中还是静止中还是在释放技能、挖矿、采药等

人物状态数据期望的样子

0:表示站着不动

1:表示移动

2:表示打怪

3:表示采集

4:表示释放技能中

注释:上面的数字可能与游戏中用的数字对不上,但是期望是这样的数字,范围大约0-50之间把,越小越好,下面开始找人物状态

首先打开游戏,打开CE,如下图,数据类型使用字节,扫描类型使用位置的初始值,字节的范围是0-255

首次扫描之后

首次扫描的时候人物是站着不动的状态,然后让角色移动或者其它可以修改人物状态的数据,这里就使用移动角色的操作来修改人物状态,角色移动过程中使用变动的数值再次扫描

当角色移动完成恢复到站着不动的状态后使用变动的数值再次扫描,然后紧接着使用未变动的数值再次扫描,这里注意如果使用传送技能来修改角色状态要手动取消技能,不要让角色真的传送了,有的游戏传送之后会重新把人物数据初始化,也就会导致我们使用未知的初始值扫描的数据失效

通过上方变动的数据和未变动的数据扫描剩下200多个不好过滤了

最开始说过人物状态期望的是0-50之间,这里直接用0-100进行筛选,如下图筛选玩还剩31个,这时候操作游戏修改人物状态观察数据

下方是人物移动过程中,还是有大于100的数字,这时候还是使用0到100进行再次扫描

现在满足期望的是下图红框的这几个数据,因为它们的数字很小,然后回到游戏中继续修改人物状态观察数据

最终发现下图红框的数据是人物状态,下图中它的值是2,人物移动过程中它的值会是2,移动完成又会变成0

打坐的时候值是6

释放技能的时候是5

打怪的时候是7

采集材料是8

总结

0:站着不动

2:移动中

5:释放技能中

6:打坐中

7:打怪(战斗中)

8:采集材料中

然后打开x64dbg开始找基址

然后右击选择地址

然后数值的显示方式就会变成下图的样子,这个样子比较好看(用不用看个人习惯),这里要注意修改显示类型之后地址会跳,记得重新CTRL+G到目标地址,如下图地址就变了

然后硬件访问-》字节,如下图地址就变了

然后就会在下图位置断点住

然后禁用硬件断点,禁用玩按F9让代码运行起来(代码长时间卡死不执行会让游戏掉线)

然后分析代码,人物状态是下图红框位置的代码访问的,也就是rcx+1B8访问的

rcx的值来自于rax+0x98

rax的值来自于0x00007FF7BBE4CD70基址,然后开始计算偏移

模块首地址是00007FF7BB510000

然后右击复制

结果是0x93CD70

公式\[Game.exe+0x93CD70+0x98]+0x1B8,在CE中进行验证

这里要说一点,写当前文章时游戏更新了,导致偏移变化了,它的基址实际上是与之前找到的坐标的基址是同一个,如下图使用CE验证

然后整理一下数据

5C是x坐标

60是z坐标

64是y坐标

1B8是人物状态


相关推荐
金銀銅鐵3 天前
[Python] 模 n 乘法的逆元计算器
python·数学·游戏
金銀銅鐵4 天前
借助 Pygame 探索最大公约数的规律
python·数学·游戏
nujnewnehc8 天前
不会 py, 用 ai 写了个游戏辅助的感受
人工智能·游戏
jump_jump9 天前
为了重玩金庸群侠传,我研究了一下 Ruffle 怎么复活 Flash
游戏·rust·github
XIAOHEZIcode10 天前
Linux系统鼠标偏移常见原因以及修复方案
linux·运维·游戏
Aloys_Code11 天前
逆向一个被遗忘的DVD游戏格式:从DES加密到Rust模拟器
游戏·模拟器·retroarch·复古游戏·native32·sunplus·赤刃·钢铁风暴
金銀銅鐵11 天前
用 Python 实现 Take-Away 游戏
python·游戏
金銀銅鐵12 天前
用 Pygame 实现 15 puzzle
python·数学·游戏
LDR00614 天前
Type-C 快充全面升级!LDR6601 赋能个人护理便携电机,重塑剃须刀 / 理发器新体验
c语言·开发语言
雪碧聊技术14 天前
Tree.js是什么?一文讲透
开发语言·javascript·ecmascript