解密Cocos2dx-lua XXTEA加密后.luac文件

​ 针对Cocos2dx-lua提供的轻量级加密方案的反编译。该博客参考自原文章

一般使用该轻量级加密方案的命令如下:

cocos luacompile -s 未加密源码目录 -d 加密后源码目录 -e -k 加密key -b 加密sign --disable-compile

要解密,那么需要知道的是加密key加密sign

一、加密解密思路

​ 我们将后缀为.lua的文件加密成.luac文件,然后放入apk中,那么在程序运行时,势必需要对.luac的文件进行解密,然后再加载运行文件。那程序是如何知道我们在加密key呢?有两个猜想:

​ 1,加密key写入文件,程序在解密时先读取文件中的加密key,再解密。

​ 2,加密key与程序内部约定某个值。

显然,第一种做法很不明智,key值直接存入文件很容易破解,那么就验证第二种做法,既然加密key是约定的,那么肯定可以在程序中找到该值。通过搜索发现验证了该想法。

在工程的frameworks\runtime-src\Classes\AppDelegate.cpp文件applicationDifFinishLauching方法中

能够看到设置了加密key和sign

二、反编译luac

​ 要反编译.luac文件,需要知道加密key和sign。上面提供了一个思路,sign在.luac中寻找,key在打包后的libcocos2dlua.so中寻找。

1,寻找加密sign

​ 用记事本打开某个.luc文件,文件开头的前几个字符即加密sign

2、寻找加密key

​ 下载IDA(交互式反汇编器),将libcocos2dlua.so拖到该IDA快捷图标上,此时会弹出

选择 OK,等待加载function name,避免操作应用是卡住。等会后选择view/open subviews/strings

Ctrl + F 搜索 刚刚获取的sign(XXTEA),得到如下结果

点击该结果,在该结果的附近则能够发现加密key(2dxLua)

3、加密key,加密sign已经获取,如何反编译

cocos使用的XXTEA进行加密,其在external目录下,在xxtea.h可以看到,提供了加密解密方法

#ifndef XXTEA_H
#define XXTEA_H#include <stddef.h> /* for size_t & NULL declarations */#if defined(_MSC_VER)typedef unsigned __int32 xxtea_long;#else#if defined(__FreeBSD__) && __FreeBSD__ < 5
/* FreeBSD 4 doesn't have stdint.h file */
#include <inttypes.h>
#else
#include <stdint.h>
#endiftypedef uint32_t xxtea_long;#endif /* end of if defined(_MSC_VER) */#define XXTEA_MX (z >> 5 ^ y << 2) + (y >> 3 ^ z << 4) ^ (sum ^ y) + (k[p & 3 ^ e] ^ z)
#define XXTEA_DELTA 0x9e3779b9unsigned char *xxtea_encrypt(unsigned char *data, xxtea_long data_len, unsigned char *key, xxtea_long key_len, xxtea_long *ret_length);
unsigned char *xxtea_decrypt(unsigned char *data, xxtea_long data_len, unsigned char *key, xxtea_long key_len, xxtea_long *ret_length);#endif

4、运行cpp文件,调用解密方法,解密.luac文件

win上运行cpp文件,可以按照MinGW MinGW,选择mingw-get-setup.exe。选中里面的mingw32-gcc-g+±bin进行安装。安装完成后配置下环境变量,安装目录下的bin,例如D:\MinGW\bin

在cocos引擎external目录下复制一份xxtea.cpp和xxtea.h,修改xxtea.cpp的后缀名为xxtea.c,不知为啥,用.cpp后缀就是生成不了exe文件。然后编写一个入口文件,main.c

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include"xxtea.h"
int main(int argc,char*argv[]){FILE*fp;char*key;char*sign;char*infile;char*outfile;char*buf,*data;unsigned long size;int keylen,signlen,retlen;if(argc<5){printf("usage:lua_decrypt infile outfile sign key\n");return -1;}else{infile=argv[1];outfile=argv[2];sign=argv[3];key=argv[4];keylen=strlen(key);signlen=strlen(sign);}if((fp=fopen(infile,"rb"))==NULL){perror("can't open the input file");return -1;}fseek(fp, 0L, SEEK_END);size=ftell(fp);rewind(fp);buf=(char*)malloc(size);fread(buf,size,1,fp);fclose(fp);data=xxtea_decrypt(buf+signlen,size-signlen,key,keylen,&retlen);if(data==NULL){printf("%s decrypt fail\n",infile);return -1;}if((fp=fopen(outfile,"wb+"))==NULL){perror("can't open the output file");return -1;}fwrite(data,retlen,1,fp);fclose(fp);free(data);printf("%s decrypt successful\n",infile);return 0;}

将这三个xxtea.c xxtea.h main.c这三个文件放在同一个目录下,进入cmd,进入该目录下,键入

gcc xxteac main.c -o luac_decrypt生成luac_decrypt.exe,然后将要解密的.luac文件放在该目录下,键入

luac_decrypt xx.luac xx.lua sign key即可反编译.luac文件。

例如放置了version.luac文件在该目录,sign是XXTEA,key是2dxLua,即命令如下:

luac_decrypt version.luac version.lua XXTEA 2dxLua即可以反编译后输出文件version.lua

三、扩展,批处理

​ 每次都是命令行反编译一个文件,显示效率低效。可以编写批处理,设置luac文件夹,输出文件夹,反编译exe路径,sign,key,然后循环反编译luac文件夹下所有的.luac文件

rem "decompile Luac script"
echo off
rem set your luac direction
set sourcePath=C:\Users\86181\Desktop\luac
rem set your luac_decrypt.exe path
set decryptPath=C:\Users\86181\Desktop\luac_decrypt.exe
rem outfile direction
set outfilePath=C:\Users\86181\Desktop\lua\
set suffix=.lua
set sign=XXTEA
set key=2dxLuamd %outfilePath%for /r %sourcePath% %%i in (*.luac) do ( %decryptPath% %%i %outfilePath%%%~ni%suffix% %sign% %key%
)pause

反编译Luac加密的.luac文件

一、.lua文件编译为字节码文件.luac

​ lua中自带将.lua文件编译为字节码文件,命令行luac -o 输出文件 源文件

在桌面新建文件夹aaa,放入源文件helper.lua命令行中执行

luac -o helper_luac.luac helper.lua会在aaa文件夹下生成helper_luac.luac文件,用记事本打开该文件。

二、.luac文件反编译为.lua文件

​ 下载unluac.jar包,官网地址

将下载后的包重命名为unluac.jar,并拖动到aaa文件夹下,执行命令java -jar unluac.jar helper_luac.luac>helper_decrypt.lua(需要支持java命令),这时会在aaa文件夹下生成helper_decrpyt.lua,将原本的helper.lua与反编译后的helper_decrpyt.lua进行对比,发现除了某些格式,代码基本一致,反编译成功。

两种.luac的反编译过程相关推荐

  1. 使用高级语言编写计算机程序步骤,计算机执行用高级语言编写的程序主要有两种途径解释和编译编译专.doc...

    计算机执行用高级语言编写的程序主要有两种途径解释和编译编译专.doc 计算机执行用高级语言编写的程序主要有两种途径:解释和编译 编译:专指由高级语言转换为低级语言编译和解释的区别: 是否产生目标程序 ...

  2. 记录一次python3.7反编译过程

    记录一次python3.7反编译过程 1.将exe文件转换成pyc文件 2.修复pyc文件 3.如何得到magic number 4.添加magic number 5.反编译pyc文件 找到了一个py ...

  3. Linux centos7升级内核(两种方法:内核编译和yum更新)

                Linux centos7升级内核(两种方法:内核编译和yum更新) Linux的内核概念不用说大家也很清楚,正是内核版本的不同,才有Linux发行版本的说法,现在主流的cen ...

  4. matlab中给信号添加高斯白噪声的两种方法,awgn计算过程,randn函数

    y=awgn(x,snr,px_dBW) 给信号x添加噪声功率为某个值的高斯白噪声. snr为信噪比,单位dB. px_dBW为信号x的指定功率(注意,是指定功率,而不是x本身的功率),单位dBW. ...

  5. 将exe4j打包的java exe程序反编译过程

    开始,我用了http://blog.csdn.net/lanximu/article/details/16879545的方法,但十六进制文件看着有乱码,试着截了几次进行压缩,但都不对,不管是用ultr ...

  6. 两个小工具反编译微信(PC)小程序源码

    现在微信小程序有很多,但是想自己开发时候遇到技术瓶颈想参考(借鉴)别人小程序怎么办,网上资料又很少,很多坑爹的需要付费.作为搞技术的人直接把小程序反编译是不是更直接,接下来敲小黑板. 我们用到的工具很 ...

  7. Java编译和执行模式包括两种,Java程序的编译和执行模式包括2点,是【 】和半解释。...

    参考答案如下 植物的根瘤().A. 有助于根的吸收作用B.可提高土壤酸性c.有固氮作用D. 可产生维生素,程序促进根系 关于水流,编2点以下正确的是:()A.流向是指水流流去的方向B.流向是指水流流来 ...

  8. 最新微信小程序反编译破解过程记录

    一.前言 既然你进来看这篇文章,我认为"微信小程序反编译"这个技术你多少应该会了解点.在学习微信小程序前端开发的过程中,我跟大部分人一样,试着仿写过一些线上的小程序案例,但在实际练 ...

  9. 记一次APK反编译,拿到自己想要的API过程及应用

    目的 我的电脑装了一个开机卡 本身已提供了windows和Android和微信的程序 我使用的是iPhone,想拿到API 写快捷指令,这样就可以通过 嘿,Siri 打开/关闭/重启电脑 (现有的ap ...

  10. Android APK反编译具体解释(附图)

    这段时间在学Android应用开发,在想既然是用Java开发的应该非常好反编译从而得到源码吧,google了一下,确实非常easy,下面是我的实践过程. 在此郑重声明,贴出来的目的不是为了去破解人家的 ...

最新文章

  1. AD环境部署文件服务器2012,Windows_server_2012部署AD域及辅域环境.doc
  2. Windows 2008 远程登陆时提示要登录到此远程计算机,您必须被授予允许通过终端登录登录的权限...
  3. LVS负载均衡之持久性连接介绍(session篇)
  4. 自言自语(三)--部分中文字体
  5. python学习笔记(二)——散列类型(字典、集合)
  6. unix grep命令的大致实现
  7. 二十四、TextCNN的原理和实现
  8. C与c++中-什么时候用,头文件中与“”区别
  9. RIP路由六大防环机制
  10. Access 操作必须使用可更新查询
  11. centos7静默搭建oracle11g,centos7下静默安装oracle11G图解配置 1
  12. 多线程常见面试题(含常见项目遇到多线程问题解决及面试对话)
  13. 语音转文字的测试用例
  14. Nacos配置中心实战,盘古开发框架标配组件
  15. 求树的直径的两种方法
  16. VMware中linux环境下oracle安装图文教程(一)
  17. opengl剪裁空间和视口空间中不遵从右手定则,而是遵从左手定则
  18. Android 二维码 生成和识别
  19. 基于Wallpaper Engine的html插件罗盘时钟实现及简易桌面替换
  20. hooks 使用dva_Tarodemo

热门文章

  1. ad自动布线过孔_AD15布线方法汇总
  2. 沟通CTBS金融行业远程接入解决方案
  3. python画二次函数图像的顶点坐标为_Python绘制函数图像
  4. STM32F030外部中断配置
  5. PMP第十一章:项目风险管理
  6. android显示超图地图,超图---简单地图显示
  7. 什么是多径效应?多径效应怎么消除?多径效应解决方法
  8. android文件读取文件内容,android创建txt文件,读取txt文件内容
  9. 同构数怎么判断_判断同构数C语言
  10. 尚硅谷 模拟w3school首页导航条练习