吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 17178|回复: 137
收起左侧

[游戏安全] [原创]CE进阶操作之Tutorial Game学习

    [复制链接]
低调的菜鸡 发表于 2020-7-19 12:37
本帖最后由 低调的菜鸡 于 2020-7-19 12:44 编辑

一、背景

​        最近玩CE的时候,突然发现Help菜单里面居然还藏着一个小游戏,花了半天时间,终于使用CE完成了所有关卡,现在分享给大家,也可以和大家共同加深CE功能的学习。

二、环境

系统:windows 10

调试器:Cheat Engine 7.1

目标游戏:CE自带的TutorialGame

三、游戏过关攻略

1.第一关

​        观察游戏

​        首先,我们打开游戏,选择第一关,全通关后需要选择,没通关的话直接进去就是第一关,CE附加游戏。

1.png

​        观察游戏界面如下:
2.png

​        这里会有一个提示,每5次射击后,子弹会重装,之后目标会治疗,试着找出一种方式摧毁目标,经过我们的尝试,发现单纯射击,确实干不掉它。子弹打完它就满血了。

​        过关思路:我们可以找到放子弹的变量,然后将其锁定,即可让子弹永远打不完,从而绕过目标的治疗。

​        开始操作

​        首先,搜索当前子弹数量,射击,再次搜索子弹数量,这是一种常见的变量搜索方法,也是CE里面最强大的一种方法。

​         3.png

4.png

5.png

​        这时候我们发现问题了,搜到后面,发现没有结果了?我们思路肯定出现了一点问题,或许子弹不是减少,而是增加?增加到5就重置?好的,打光子弹,从0开始搜索,搜索结果如下:

​         6.png

7.png
8.png
9.png

​        我们似乎找到了一个和我们预想差不多的变量地址,这里双击添加到我们的地址列表,选中后空格键锁定,在游戏中发现,不管我们怎么发射子弹,敌人血量都不重置了。

​         10.png

​        到目前为止,我们就能干掉这个目标了,但我们尝试用一种快乐的方法干掉他。

​        在地址列表中,右键,查找是什么改写了该变量。

​         11.png

​        在游戏中开一枪,我们看到改变此变量的指令,跳转到反汇编窗口

​         12.png

​        在反汇编窗口,可以看到,该指令是将这个变量加一,如果我们改为+0,或者nop,就可以实现无限子弹了。
13.png

​        选中该指令,ctrl+a出现自动汇编窗口,模板中选择AOB注入,更改掉当前指令,这里直接注释即可,然后File->Assign to current cheat table,添加到当前作弊列表中。

14.png

​        在地址列表选中脚本,可以看到相应的汇编指令已经改变,跳转到我们的代码执行了。
15.png
16.png

​        此时,应用我们的脚本,即可快乐度过第一关

17.png

2.第二关

观察游戏
18.png

​        可以看到这里也是有提示的,我们有2个高血量高伤害的敌人,我们需要干掉他们。然后有一个警告,敌人和玩家是有关联的。

绕过思路:

​        首先,秦王绕柱走。走位走位,那个回手掏。然后发现操作太蛇皮了,反人类的移动,没办法,感兴趣的朋友们可以练练走位,然后干掉它俩。接下来介绍我个人的2种过关思路:

​        (1)我们锁血了,按道理说就能直接干掉他俩了。

​        (2)我们找到扣血代码,然后hook,在扣血前判断,如果是自己就不扣血,如果是敌人就秒杀。

开始操作:

​        先搜索自己的血量,这里方法和前面是一致的。根据屏幕上的显示进行搜索,或者根据被攻击的次数,选择减少的数值,也能找到自己的血量,操作过程如下:

​         19.png

20.png

​        更改数值,发现游戏内数值也改变,我们找到了血量变量地址




21.png


​        锁定该血量。干掉2个敌人。

​        血量掉的贼慢,开始第二种方法。

​        和第一关一样的操作,查找是什么改写了这个地址,然后进入游戏,让自己被打一枪。
23.png

​        进入反汇编窗口,查看代码,看到前后都是00 00,只有3条代码,可以猜测此处应当是血量扣除的代码。

​        右键,查看这条指令访问的地址,从而找出敌人的血量

24.png

​        会弹一个小框出来,我们进入游戏,和敌人相爱相杀,小框会记录每次该指令访问的地址。

​         25.png

​        因为游戏提示说,玩家和敌人其实是有关联的,所以我们分析一下数据结构,这里选中这3个地址,右键->打开指定地址并剖析数据。

26.png

​        一系列确定之后,可以看到,结构体窗口如下:

27.png

​        我们很快就在偏移0x60处找到了血量,并且在0x70处找到了阵营信息。
28.png

​        现在我们可以开始优雅的过关了。选中扣血代码,ctrl+a进入自动汇编,选择AOB注入模板。

29.png

​        现在我们新建一个标签,名为kill,表示立刻杀死当前对象,然后在代码入口处,判断当前阵营,如果为0,直接跳转到Kill,干掉,如果为1,则不进行任何操作。由于代码本身自带ret,所以我们后面的指令不会执行,不管他

30.png

​        现在试试结果吧,将脚本保存到CheapTable,运行脚本,完美过关
31.png

3.第三关

观察游戏:

32.png

​        游戏大概意思为把所有平板都变成绿色来解锁们,然后进入门就通关了。提示可以通过检测碰撞,或者利用坐标传送。

过关思路:

​        (1)找出坐标信息,由于是2D游戏,只要找到x,y即可,然后直接传送,把平台都变成绿色,最后传送到门里面

​        (2)找出碰撞代码,绕过它。

开始操作:

​        首先,我们来找人物的坐标信息。这里可以先找x,y根据编程逻辑,就跟在x的后边。而坐标一般为浮点数(PS:对于坐标原点,向右x增加,向左x减少,熟悉界面编程的应该不难理解。),查找过程如下:

33.png

34.png

35.png

36.png

至此,我们找到了正确的x值,然后我们在该地址后面+4即为y的偏移。

​         37.png

​        好的,看起来我们可以通过修改x,y的值过关了

​        当然,我们也要改一个优雅的方法,最好是能够hook代码的那种。

​        选择x的地址,右键,查看什么访问了这个地址

38.png

​        可以看到,坐标x在玩家对象中的偏移为baseAddr+24,在x处右键,内存中显示

39.png

更改显示模式为4字节整数

40.png

​        将首地址-偏移(0x24),跳转到对象首地址

41.png

​        进入游戏,不停死亡,观察该内存区域中的数值变化,发现图下方框的位置,当玩家死后,变为1,玩家存活变为0

42.png

​        将其添加到作弊表中。锁定该值,可以发现,人物无敌了

43.png
​        分别锁定,发现二者功能如下,第一个地址是表示人物是否显示,第二个地址表示人物是否死亡。

44.png

​        接下来我们怎么操作呢,找到访问该地址的代码,然后绕过它。在判断人物死亡的地址处右键,什么改写了该地址,然后进游戏死亡,查看到如下代码

45.png

​        进入反汇编,看到如下代码,若修改参数能实现无敌,但我们要的是避免碰撞,或者避免死亡检测。
46.png

​        这里我们用到CE的另一个功能,指令跟踪。

47.png

​        设置最大跟踪次数为10000,跳过系统模块和取消单步

​         48.png

​        进入游戏,死亡,得到如下结果,右键,全部展开

49.png

​        我们在第二层找到了调用这条语句的代码,双击到达反汇编代码

50.png

​        只要将je改为jmp即可绕过碰撞。选中je,ctrl+a,选择AOB注入模板,更改指令如下:

51.png

​        添加到作弊表,启用脚本,可以看到,我们已经不会和敌人碰撞了

52.png

​        接下来只要慢慢修改我们的坐标,把所有平台点绿,即可过关。
53.png

4.绕过Integrity Check

​        我们已经过关了,但是此时发现一个问题,每次我们运行脚本进行hook的时候,窗口顶部总会显示一个可恶的Integrity check error

54.png

​        现在我们来绕过它。

​        首先,打开游戏,CE附加进程,当我们运行脚本hook时,内存中我们hook的指令会被更改为jmp,所以我们先找到指令位置。搜索hook的特征码

55.png

56.png

这里解释一下,特征码就是指令在内存中的十六进制编码。通过该十六进制编码,可以在变动的内存中找到该指令地址,完成hook。AOB注入也是因为这个原理,所以稳如老狗,游戏基址随便变都能使用。

​        添加该地址到作弊列表,右键在内存窗口中查看

57.png

​        右键,给它下一个内存访问断点,查看是哪儿读取了该地址中的指令

58.png

​        现在我们看到,有3处检查了该地址处的代码
59.png

​        在反汇编窗口分析这3个访问指令,找到了如下的循环判断代码。
60.png

​        根据排查,发现将xx.exe+38E0C处的jg指令改为jmp指令,即可让检测失效,这里没有分析上下文,所以不清楚该处到底是如何实现代码检测的。

​        接下来的工作就是自动汇编(Ctrl+A)->AOB注入模板->将jg改为jmp
61.png

​        添加到作弊列表中,启用该脚本,此时用其他脚本发现,代码完整性检查已经被绕过了,接下来只要把作弊表保存一份,即可

62.png

四、总结

​        我们完成了3个关卡的作弊,以及完整性检查的绕过,但这还不够,我们应该将完整性检查的代码逆向出来,这里我就偷了一个懒,直接试出来如何绕过了,各位小伙伴感兴趣的可以继续追踪分析。

五、工具获取与源码

CE7.1工具,可以在官网上直接下载,百度或者其他搜索引擎搜索Cheap Engine即可到达官网。

演示用到的CT见附件。



附件(密码52pojie.cn).zip (7.65 KB, 下载次数: 22)
22.png

点评

我以前做过视频版的https://www.bilibili.com/video/BV1c4411475k/  发表于 2020-7-19 23:27

免费评分

参与人数 66威望 +2 吾爱币 +158 热心值 +62 收起 理由
id1123 + 1 + 1 我很赞同!
橘子哟6 + 1 + 1 谢谢@Thanks!
jstt552200 + 1 我很赞同!
MUMUAA + 1 + 1 热心回复!
controlr + 1 + 1 谢谢@Thanks!
cyberyang + 1 + 1 用心讨论,共获提升!
zsq + 1 + 1 谢谢@Thanks!
bugof52pj + 1 + 1 谢谢@Thanks!
叶一苇 + 1 学到了
vvqk + 1 + 1 感谢发布原创作品,吾爱破解论坛因你更精彩!
zhuzhuxia111 + 1 + 1 我很赞同!
也西 + 1 + 1 我很赞同!
dnldnl + 1 + 1 谢谢@Thanks!
sxisir + 1 + 1 用心讨论,共获提升!
ygwh + 1 + 1 谢谢@Thanks!
石碎大胸口 + 1 + 1 用心讨论,共获提升!
xhwljs + 1 + 1 我很赞同!
7335379 + 1 + 1 我很赞同!
lcfjeff + 1 我很赞同!
H_boy + 1 + 1 我很赞同!
JuDei + 1 + 1 谢谢@Thanks!
kkiu + 1 + 1 谢谢@Thanks!
louchen1994 + 1 + 1 我很赞同!
Mark82II + 1 + 1 学到了1.. 谢谢!
小白2号 + 1 谢谢@Thanks!
Insert + 1 + 1 我很赞同!
pixuan + 1 + 1 用心讨论,共获提升!
lyb1713 + 1 + 1 谢谢@Thanks!
西域的鱼 + 1 用心讨论,共获提升!
随风起舞 + 1 + 1 谢谢@Thanks!
大愛の向こう + 1 + 1 谢谢@Thanks!
submarine1620 + 1 感谢发布原创作品,吾爱破解论坛因你更精彩!
liujing1 + 1 + 1 用心讨论,共获提升!
flasher + 1 我很赞同!
gunxsword + 1 + 1 不需要AOB 小白估计看不懂!
正午光阳 + 1 + 1 我很赞同!
fengbolee + 1 + 1 用心讨论,共获提升!
名太帅无法显示 + 1 + 1 用心讨论,共获提升!
NEWBEESL + 1 + 1 我很赞同!
小白鹿o + 1 + 1 挺好的
Harley123 + 1 我很赞同!
空山鸟语灬 + 1 + 1 热心回复!
落雨凡心 + 1 + 1 用心讨论,共获提升!
超无奥义 + 1 + 1 用心讨论,共获提升!
lffuzai + 1 + 1 用心讨论,共获提升!
SF-10086 + 1 + 1 热心回复!
国际豆哥 + 1 + 1 我很赞同!
gdyang + 1 + 1 欢迎分析讨论交流,吾爱破解论坛有你更精彩!
tony198911 + 1 + 1 用心讨论,共获提升!
gaosld + 1 + 1 热心回复!
pifu123 + 1 + 1 我很赞同!
qalong + 1 谢谢@Thanks!
Hmily + 2 + 100 + 1 感谢发布原创作品,吾爱破解论坛因你更精彩!
Daihui + 1 + 1 谢谢@Thanks!
挥汗如雨 + 2 + 1 热心回复!
草飞天下 + 1 你这样打游戏是没有灵魂的。。。
宅宅男 + 1 + 1 之前玩过 才到第四关就卡了。。。
连晋 + 1 + 1 已经处理,感谢您对吾爱破解论坛的支持!
endriver + 1 我很赞同!
durongze + 1 我很赞同!
Dboykey + 1 + 1 谢谢@Thanks!
livetome + 1 + 1 用心讨论,共获提升!
dliwj + 1 + 1 用心讨论,共获提升!
789749794 + 1 + 1 我很赞同!
dmxayjn + 1 + 1 我很赞同!
vethenc + 1 + 1 我很赞同!

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

45354604 发表于 2020-7-19 18:20
感谢大佬分享,多多少少看的懂1点
alicc 发表于 2020-7-19 13:27
通过这些关顶多算入门了。后面各种游戏细节又是一门学问了
 楼主| 低调的菜鸡 发表于 2020-7-19 12:46
不知道为啥,22号图片错位了,咋调都调不回去
vethenc 发表于 2020-7-19 13:00
感谢分享
dmxayjn 发表于 2020-7-19 13:02
教程写的很详细。期待出更多的。
为乐当及时~ 发表于 2020-7-19 13:13
感谢分享!!
Windows10 发表于 2020-7-19 13:49
调成中文不好么
致远英才 发表于 2020-7-19 14:19
感谢分享,学习了,希望能继续分享!
天空の幻像 发表于 2020-7-19 17:31
大佬,厉害,学习学习
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2025-1-2 22:15

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表