本人只是为了学习,
长话短说,直接上,首先拿到一个apk 我们反编译一波,发现游戏类的apk基本都是 用U3d, 或者cocos开发的,2d的游戏基本都是卡牌,或者棋牌之类的游戏,我们需要看到源码的逻辑,但是源码是被加密的,怎么才能得到源码,我们需要将 jsc文件变成js文件,对于cocos的游戏大多数都是 JavaScript 写的,apktool解包看看,project.jsc 是被加密后的源码文件,
接下来你会发现jsc文件是打不开的,二进制。
来分析libcocos2djs.so 是一个很重要的文件,用IDA 打开这个so文件,去分析,里面有加解密的逻辑,他的秘钥也是在这个里面,在用winHex 慢慢分析. 找到秘钥 再用 xxtea工具 去解密,解密完就能看到源码.
我提供以下线索,希望你们能通过自己的研究,也找到相同的破解方法。
准备这些工具:adb,xxtea,zip,apktool,jarsigner,字节码分析工具(自己写代码分析二进制流)
步骤:apktool解包 -> 字节码分析工具找到密码 -> xxtea解密文件 ->