python反编译luac_LuaJIT反编译总结

本文介绍了如何反编译luajit字节码,对比了两种反编译方案,重点分析了ljd反编译工具的源码,发现了存在的bug,并详细阐述了bug原因及修复方法。通过修正后的工具,可以针对带有或不带调试信息的luajit字节码文件进行不同程度的反编译。
摘要由CSDN通过智能技术生成

本文所指luajit,皆指luajit2.1.0-beta2版本。

一、背景

逆向apk时,得到luajit字节码文件,将反编译luajit的过程记录如下。

本文主要分析ljd反编译工具源码(https://github.com/NightNord/ljd),并参照feicong的luajit字节码分析一文(https://github.com/feicong/lua_re/blob/master/lua/lua_re3.md),制作Luajit字节码文件格式结构图以直观反映luajit字节码文件格式,并对ljd中存在的bug进行修正,说明使用过程中遇到的问题。

二、反编译luajit字节码前期准备

搜集资料,找到两种解决方案。

方案一

将luajit字节码文件用luajit.exe(luajit -bl luajit-byte-path)反编成操作码文件,然后再将操作码文件解析成可读文件。

用autoit编写,下载下来的有打包好的exe文件,简单测试的话可以按如下操作:

1.下载编译字节码文件对应版本的luajit,可以自己编译,编译好后,将luajit.exe及对应的dll、lib等文件及源码目录下的jit文件夹一同拷贝进luajit-decomp目录。

2.将需要测试的luajit字节码文件拷贝至luajit-decomp目录,并重命名为test.lua

3.双击运行,会生成out.lua文件。

反编译效果如下图:

6ea1e981bd2320f5cc99f8773a323802.png效果不如人意,对此不做具体分析。

方案二

分析luajit字节码文件,及对应版本的luajit源码,写反编译工具将字节码直接反编译成luajit源码。我们主要分析这种。

过程中主要参照这三篇文章:

三、Ljd源码分析

(1)ljd目录结构说明

9e5d8e7f7572b334941038bac2c56385.png(2)ljd函数调用流程分析

画了一张解析时调用流程图:

Python中,可以使用unluac模块来反编译luac_Lua程序。具体步骤如下: 1. 安装unluac模块。可以使用pip命令进行安装,命令如下: ``` pip install unluac ``` 2. 编写Python脚本来调用unluac模块进行反编译。以下是一个简单的示例脚本: ``` import unluac with open('test.luac', 'rb') as f: data = f.read() decompiled = unluac.decompile(data) with open('test.lua', 'w') as f: f.write(decompiled) ``` 该脚本将test.luac文件反编译为test.lua文件。 3. 将反编译后的Lua代码导入到IDA Pro中。可以使用IDA Pro的Lua插件进行处理。 1. 在IDA Pro中,选择File -> Script file,打开Lua脚本窗口。 2. 在窗口中输入以下代码: ``` local f = io.open("test.lua", "r") local content = f:read("*all") f:close() LoadSource(content, "test.lua") ``` 3. 点击Run按钮,将Lua代码加载到IDA Pro中。 4. 编写IDA Pro处理器模块。可以使用IDA Pro的Python API编写处理器模块,对Lua代码进行分析和处理。以下是一个示例模块: ``` import idaapi class LuaProcessor(idaapi.processor_t): id = 0x8000 + 1 flag = idaapi.PR_USE32 | idaapi.PR_DEFSEG32 cnbits = 8 dnbits = 8 psnames = ["luac"] plnames = ["Luac bytecode"] segreg_size = 0 instruc_start = 0 assembler = { "flag" : flag, "uflag" : 0, "name" : "Luac assembler", "origin" : "luac", "notify" : None, "header" : None, "footer" : None, "segstart" : None, "segend" : None, "assume" : None, "flag2" : 0, "cmnt" : ";", "ascsep" : '"', "accsep" : "'", "esccodes" : "\"'", "a_ascii" : "db", "a_byte" : "db", "a_word" : "dw", "a_dword" : "dd", "a_qword" : "dq", "a_oword" : "xmmword", "a_float" : "dd", "a_double" : "dq", "a_tbyte" : "dt", "a_packreal" : "dq", "a_dups" : "#dups", "a_bss" : "res", "a_seg" : "seg", "a_curip" : "$", "a_public" : "public", "a_weak" : "weak", "a_extrn" : "extrn", "a_comdef" : "comm", "a_align" : "align", "lbrace" : "(", "rbrace" : ")", "a_mod" : "%", "a_band" : "&", "a_bor" : "|", "a_xor" : "^", "a_bnot" : "~", "a_shl" : "<<", "a_shr" : ">>", "a_sizeof_fmt" : "size %s", } def PROCESSOR_ENTRY(): return LuaProcessor() ``` 该模块将Lua代码识别为Luac bytecode,并使用Luac assembler进行处理。 以上就是使用Python反编译luac_Lua程序并为其编写IDA Pro处理器模块的一般步骤。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值