APK 概述
CrakeMe04是一个文字类型的放置游戏。代码基于java。

特此声明:本文只是用来学习使用,禁止用于商业或其他用途,违者后果自负!

由于是基于java代码写的,所以逻辑比较简单。我们这里只要修改初始金币数量就可以了,其他的读者可以自行修改。这里作者建议不要修改太多,以免失去游戏乐趣。

游戏主界面:
Android逆向之CrakeMe系列------04

游戏商店界面: 初始金币为100

Android逆向之CrakeMe系列------04

分析工具
  • Apktool 2.4.1
  • Android Killer v1.3.1.0
过程

1.直接把apk包拉入AndroidKiller中
Android逆向之CrakeMe系列------04

2.我们要搜索关键字,搜什么呢?在商店界面可以看到初始值100GP,那么我们就在游戏中搜索100. 这里要记得先把10进制的100转换为16进制,再去搜索。

100的16进制就是0x64。我们工程里搜索0x64

Android逆向之CrakeMe系列------04

3.开始分析搜索结果
(1)android包和google包都不用看,直接看项目包中的搜索结果。
Android逆向之CrakeMe系列------04

(2)最终定位到GameContext这个类中
我们用jeb打开看下,定位到这一行
Android逆向之CrakeMe系列------04

4.由上可得知,可能是在上下文初始化的时候给金币赋值。我们这里给个10000的初始化值,10000的16进制值是0x2710
所以我们回到smali文件,GameContext中修改对应的值。
Android逆向之CrakeMe系列------04

修改后
Android逆向之CrakeMe系列------04

5.编译,打包,签名,进入游戏
Android逆向之CrakeMe系列------04

修改成功~~~

总结:这种纯java代码写的app逻辑比较简单,逆向的话只要理好逻辑,很容易找到突破点。

相关文章: