吾爱破解 - LCG - LSG |安卓破解|病毒分析|www.52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 11447|回复: 36
收起左侧

[游戏安全] [原创] CE基础-自动汇编:植物大战僵尸之子弹回旋

  [复制链接]
御坂00001号 发表于 2020-3-4 13:12
本帖最后由 御坂00001号 于 2020-3-4 13:12 编辑

功能实现:子弹回旋

实现基础
  1. 子弹x坐标可以增加,也可以反向减少
  2. 子弹具有流程
    击中僵尸:子弹产生 -> 子弹飞行 -> 子弹击中僵尸 -> 僵尸掉血 -> 子弹爆炸 -> 子弹消失
    未击中僵尸:子弹产生 -> 子弹飞行 -> 检查边界 -> 子弹消失
  3. 子弹可以穿透

实现分析
  逻辑分析
     1. 首先根据子弹产生,消失标志由1变0;子弹击中,消失标志由0变1 -> 可以得到修改此处代码 0046EB2B - C6 46 50 01 - mov byte ptr [esi+50],01 为0赋值,以使子弹在击中后不消失
     2. 其次,找子弹飞行相关代码,这个可以根据子弹x坐标变化找到三处(飞行时、击中时、产生时),查看飞行时的相关代码,可以得到子弹x坐标减少和增加的代码段
[Asm] 纯文本查看 复制代码
0046DBD7 - D9 43 30              - fld dword ptr [ebx+30] { 子弹x坐标减少 }
0046DBDA - DC 25 A0966700        - fsub qword ptr [006796A0] { (3.33) }
0046DBE0 - D9 5B 30              - fstp dword ptr [ebx+30]

[Asm] 纯文本查看 复制代码
0046DBE8 - D9 43 30              - fld dword ptr [ebx+30] { 子弹x坐标增加 }
0046DBEB - DC 05 A0966700        - fadd qword ptr [006796A0] { (3.33) }
0046DBF1 - D9 5B 30              - fstp dword ptr [ebx+30]

     3. 最后,找子弹边界检查相关代码,我们可以在这里实行代码注入(其实也可以在上面代码处注入),边界代码如下,见代码分析
[Asm] 纯文本查看 复制代码
0046CE9D - D9 45 30              - fld dword ptr [ebp+30] { 子弹x坐标 }
0046CEA0 - DC 1D 38976700        - fcomp qword ptr [00679738] { 左边界 }
0046CEA6 - DFE0                  - fnstsw ax
0046CEA8 - F6 C4 41              - test ah,41 { 若 子弹x坐标 >= 左边界,则跳 }
0046CEAB - 0F84 96010000         - je 0046D047
0046CEB1 - DB 45 10              - fild dword ptr [ebp+10]
0046CEB4 - D8 45 30              - fadd dword ptr [ebp+30] { 子弹x坐标 }
0046CEB7 - DC 1D 98926700        - fcomp qword ptr [00679298] { 右边界 }
0046CEBD - DFE0                  - fnstsw ax
0046CEBF - F6 C4 05              - test ah,05 { 若 子弹x坐标 < 右边界,则跳 }
0046CEC2 - 0F8B 7F010000         - jnp 0046D047

  代码分析
[Asm] 纯文本查看 复制代码
[ENABLE]
//code from here to '[DISABLE]' will be used to enable the cheat
alloc(newmem,2048)
label(returnhere)
label(originalcode)
label(exit)
// 代码逻辑:先开辟一段可用空间,用来存放方向标志;然后根据(当前子弹x坐标地址 - 首颗子弹x坐标地址) / 0x94(0x94为子弹x坐标的间隔) 可以得到当前是第几颗子弹,从而取到方向标志;
最后根据方向标志来决定子弹x坐标是增加还是减少,并对越过边界的子弹修改其方向标志
newmem: //this is allocated memory, you have read,write,execute access
//place your code here
push ecx
push ebx
push eax
push edx
xor edx,edx
mov ecx,[6A9EC0]
mov ecx,[ecx+768]
mov ecx,[ecx+c8] // 子弹x坐标首地址
lea eax,[ebx+30] // 子弹x坐标现地址
sub eax,ecx
mov ecx,94 // 子弹x坐标间隔(第1颗子弹与第2颗子弹)
div ecx // eax:第几个, 从0开始
xor edx,edx // 清零
add eax,00699000 // 00699000+index, 用来存放子弹的方向标志
mov ecx,eax
mov dl,[ecx] // 只存在低字节
cmp edx,0
pop edx
pop eax
pop ebx // 暂时不弹ecx, 因为ecx还有用
je addx

subx: // 子弹x坐标减少
fld dword ptr [ebp+30]
fsub qword ptr [006796A0]
fsub qword ptr [006796A0]
fstp dword ptr [ebp+30]

coml: // 左边界检查
push eax
fild dword ptr [ebp+10]
fadd dword ptr [ebp+30]
fcomp qword ptr [00679298]
fnstsw ax
test ah,05 // 若子弹x坐标 < 0, 则跳
jnp leftb
pop eax
pop ecx
jmp 0046CEC8

leftb: // 越过左边界, 则置相反标志
mov byte ptr [ecx],00
pop eax
pop ecx
jmp 0046CEC8

addx: // 子弹x坐标增加
fld dword ptr [ebp+30]
fadd qword ptr [006796A0]
fadd qword ptr [006796A0]
fstp dword ptr [ebp+30]

comr: // 右边界检查
push eax
fldpi
fld dword ptr [ebp+30]
fadd st(0),st(1)
fcomp qword ptr [00679738]
fnstsw ax
test ah,41 // 若子弹x坐标 >= 800, 则跳
je rightb
pop eax
pop ecx
jmp 0046CEC8

rightb: // 超出右边界, 则置相反标志
mov byte ptr [ecx],01
pop eax
pop ecx
jmp 0046CEC8

originalcode:
//fld dword ptr [ebp+30]
//fcomp qword ptr [00679738]
jmp newmem

exit:
jmp returnhere

"PlantsVsZombies.exe"+6CE9D:
jmp newmem
nop 4
returnhere:


 
 
[DISABLE]
//code from here till the end of the code will be used to disable the cheat
dealloc(newmem)
"PlantsVsZombies.exe"+6CE9D:
fld dword ptr [ebp+30]
fcomp qword ptr [00679738]
fnstsw ax
test ah,41
je 0046D047
fild dword ptr [ebp+10]
fadd dword ptr [ebp+30]
fcomp qword ptr [00679298]
fnstsw ax
test ah,05
jnp 0046D047
//Alt: db D9 45 30 DC 1D 38 97 67 00


实际效果
   实际效果_修改.png

最后总结
  虽然代码上逻辑没啥大问题,但会产生几个bug:①下一关再开,可能植物/僵尸不会重绘 ②僵尸可以走第6行 ③某些僵尸过度重绘
  到此为止,植物大战僵尸能改的都改了,可能超过子弹跟踪和子弹回旋的难度很难再有,前者为修改关键跳,后者为修改程序逻辑
  此贴可能会继续更新,只是把一些bug解决。。。。。。
end

免费评分

参与人数 16吾爱币 +21 热心值 +14 收起 理由
Tt2982 + 1 + 1 用心讨论,共获提升!
laotun + 1 + 1 我很赞同!
zhouyy + 1 + 1 感谢发布原创作品,吾爱破解论坛因你更精彩!
Hmily + 7 + 1 欢迎分析讨论交流,吾爱破解论坛有你更精彩!
ls0928 + 1 + 1 热心回复!
余弦 + 1 谢谢@Thanks!
Likiu + 1 + 1 谢谢 @Thanks!
UkissMe + 1 + 1 外币外币,外币巴伯, are u good 马来西亚
馊衣they + 1 僵尸走第六行好骚
v0id_alphc + 1 + 1 我很赞同!
llx4445630 + 1 + 1 我很赞同!
gunxsword + 1 + 1 我很赞同!
haoduoyu + 1 我很赞同!
dsdsddss + 1 + 1 热心回复!
sniper9527 + 1 + 1 谢谢@Thanks!
弗雷迪 + 1 + 1 谢谢@Thanks!

查看全部评分

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

半妆 发表于 2020-3-4 20:10
看到你这 我有了个想法 对个暗号 bcdr ???能回我一下吗 我看看是不是组织的人 顺便回复告诉我编号
Mir丶翰林 发表于 2020-3-4 13:27
李栩翊 发表于 2020-3-4 13:31
惊爆点男主 发表于 2020-3-4 13:35
僵尸可能走第六行??
弗雷迪 发表于 2020-3-4 13:35
牛逼啊,学习了!
wysyz 发表于 2020-3-4 13:36
虽然不用,帮顶一下
zncliving 发表于 2020-3-4 13:37
这玩法牛  另辟蹊径
cococat 发表于 2020-3-4 13:38
大神把子弹玩弄于股掌之间啊
橘子树先生 发表于 2020-3-4 14:08
第一次见这种修改,还能用CE改的,支持。
zhijiandeyanhuo 发表于 2020-3-4 14:26
虽然不用,帮顶一下
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则 警告:本版块禁止灌水或回复与主题无关内容,违者重罚!

快速回复 收藏帖子 返回列表 搜索

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

GMT+8, 2024-4-18 19:40

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

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