cocos2d-LUA逆向中如何解密app资源

还是以大神apk为例,通过前面分析app解密lua脚本,我们能够解密大神apk的lua脚本,现在我们来解密其资源(配置文件和图片等)。我们以比较重要的配置文件为例,未解密之前:
cocos2d-LUA逆向中如何解密app资源

文件头部也有签名值:fuckyou!。看到这,我们首先就想到是不是也是用xxtea加密的,我们用上面的方法,先xxtea解密,再解压,发现依旧是乱码,在操作的过程中就出现了错误,显然,要否定我们刚才的猜想。我们继续按部就班的解密配置文件。

稍微思考一下,文件头部是:fuckyou!如果想对文件进行解密,那么不可避免的需要处理字符串:fuckyou!,所以,我们应该能在idaPro中搜到fuckyou字符串,然后以fuckyou字符串所在代码段处的函数分析调试解密即可。验证一下我们的猜想,打开idaPro,打开string视图,搜索fuckyou:

cocos2d-LUA逆向中如何解密app资源

居然啥也没有!猜测应该是做过优化,在某个地方把字符串优化掉了。

线索断了,但是好奇心还是让我们继续,这时候,我们可以浏览cocos2d框架源码,结合网上一些资料,发现cocos2d对文件的处理封装到了CCFileUtils类中:

cocos2d-LUA逆向中如何解密app资源

函数有些多,不一一贴了,从网上也找到了前辈的经验:

cocos2d-LUA逆向中如何解密app资源

好了,我们现在回到idaPro,在export窗口,搜索getData:

cocos2d-LUA逆向中如何解密app资源

进这两个函数,反编译看下,长得不大像,略过,但是先记下,在动态调式时,我们可以在此下个断。

我们再来看getFileData:

cocos2d-LUA逆向中如何解密app资源

由于app运行在Android平台上,我们看Android平台的CCFileUtilsAndroid::getFileData:

cocos2d-LUA逆向中如何解密app资源

我们接着跟踪:

cocos2d-LUA逆向中如何解密app资源

代码很长,就不全贴了,贴此函数关键的部分:

cocos2d-LUA逆向中如何解密app资源

看到上图,感觉就是它了,呵呵!但是我们还是需要继续分析验证。函数处理文件头部sign时,并不是直接与字符比较而是与其ASCII值一个一个比较,所以我们在字符串窗口是搜不到fuckyou!的。接着往下看,当函数判断完是符合加密格式的文本时,会移除前8个字节(fuckyou!),然后与异或表中的值进行异或操作,每256个字节循环操作。

我们可以看下byte_A1C55F:

cocos2d-LUA逆向中如何解密app资源

至此,我们已基本可以确定文件解密函数及过程了,我们可以动态调试,再确认一下,当app调用完这个函数后,内存中应该是明文内容了。当我们调试时,分别在getData、CCFileUtilsAndroid:doGetFileData函数开始和结束时下断,GetData函数下断:

cocos2d-LUA逆向中如何解密app资源

doGetFileData函数下断:

cocos2d-LUA逆向中如何解密app资源

虽然两个函数都下断了,但是只在doGetFileData断点出暂停,说明解密过程中是走的doGetFileData函数,符合我们的预期,看下寄存器及内存:

cocos2d-LUA逆向中如何解密app资源

cocos2d-LUA逆向中如何解密app资源

我们看到内容在doGetFileData之前是密文,函数返回之前已经解密成明文了,这说明我们之前的分析是对的。

好了,现在,我们可以将异或表byte_A1C55F拷贝出来,然后模仿app的解密过程(可从GitHub上找个xor解码脚本,稍作修改即可)写一个小工具,对大神.apk的所有资源进行解密了:

cocos2d-LUA逆向中如何解密app资源

看完上述内容,你们对cocos2d-LUA逆向中如何解密app资源有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注亿速云行业资讯频道,感谢大家的支持。

文章标题:cocos2d-LUA逆向中如何解密app资源,发布者:亿速云,转载请注明出处:https://worktile.com/kb/p/28168

(1)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
亿速云的头像亿速云认证作者
上一篇 2022年9月21日 下午10:46
下一篇 2022年9月21日 下午10:47

相关推荐

  • 网络协作软件有哪些

    网络协作软件有:1、BoardMix,一款轻量级的数字化多人在线实时协作软件;2、Pixso,是一款设计交付一体化协作工具软件;3、石墨文档,是一款可多人实时协作的云端offce;4、金山文档,是一款可多人实时协作的云端offce;5、Worktile,是以任务或项目管理为中心的一款协作平台;6、T…

    2022年9月13日
    1.0K00
  • MySQL优化器hash join怎么使用

    前言 数据库的优化器相当于人类的大脑,大部分时候都能做出正确的决策,制定正确的执行计划,走出一条高效的路,但是它毕竟是基于某些固定的规则、算法来做的判断,有时候并没有我们人脑思维灵活,当我们确定优化器选择执行计划错误时该怎么办呢,语句上加hint,提示它选择哪条路是一种常见的优化方法。 我们知道Or…

    2022年9月15日
    71600
  • cad字体库怎么看

    cad字体库查看方法 1、右键CAD的桌面图标,找到属性一栏点击。 2、在打开的页面中,切换到快捷方式这一个栏目。 3、接着打开文件所在的位置。 4、找到Fonts文件夹。 5、Fonts文件夹就是CAD的字体库了。 以上就是“cad字体库怎么看”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这…

    2022年9月16日
    80200
  • SQL Server备份数据库的方法

    一.首先把当前的数据库备份成一个文件 1.按照操作来,选择对应的数据库, 确定备份文件的存储位置 点击确定,生成备份文件。 2.然后可以通过该备份文件还原数据库。 右键数据库点击还原文件和文件组 然后设置目标数据库的名字,如果数据库中已经存在相同名字的,则需要修改或者删除原来同名的数据库,然后在选择…

    2022年9月11日
    55400
  • mysql列转行函数指的是什么

    在mysql中,列转行函数是“group_concat()”函数;该函数用于将非空列值按照分组条件进行合并并最终返回,如果其中有空值则返回的结果是空,语法为“select group_concat(name separator ‘;’)列名 from 表名;”。 本教程操作环…

    2022年9月16日
    2.4K00
  • SQL注入中宽字节注入是什么

    宽字节注入:是属于SQL注入的一种绕过方式 一、宽字节概念: 1、单字节字符集:所有的字符都使用一个字节来表示,比如 ASCII 编码(0-127) 2、多字节字符集:在多字节字符集中,一部分字节用多个字节来表示,另一部分(可能没有)用单个字节来表示。 3、UTF-8 编码: 是一种编码的编码方式(…

    2022年9月6日
    55900
  • mysql查询慢的因素有哪些

    数据库查询流程 我们先来看下,一条查询语句下来,会经历哪些流程。 比如我们有一张数据库表 CREATE TABLE `user` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT ‘主键’, `name` varchar(100) NOT…

    2022年9月2日
    60900
  • Redis过期键删除策略的原理是什么

    Redis服务器实际使用的是惰性删除和定期删除两种策略:通过配合使用这两种删除策略,服务器可以很好地在合理使用CPU时间和避免浪费内存空间之间取得平衡。 惰性删除 惰性删除策略对CPU时间来说是最友好的:程序只会在取出键时才对键进行过期检查,这可以保证删除过期键的操作只会在非做不可的情况下进行,并且…

    2022年9月2日
    62700
  • linux能不能获取本地ip地址

    linux能获取本地ip地址。方法:1、利用“ifconfig -a”命令,该命令用于显示或者设置网络设备信息;2、利用“ip address”命令,语法为“ip address | grep eth0 | awk ‘{print$2}’”;3、利用“hostname -I”…

    2022年6月29日
    4.6K00
  • mdf文件如何开启

    mdf文件打开方法: 1、下载一个SQLServer管理工具。 2、下载好开始安装。 3、完成后点击“导入连接”。 4、找到需要打开的mdf文件点击“打开”即可。 5、打开列表即可看到mdf文件。 到此,相信大家对“mdf文件如何开启”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关…

    2022年9月8日
    62400
注册PingCode 在线客服
站长微信
站长微信
电话联系

400-800-1024

工作日9:30-21:00在线

分享本页
返回顶部