Dar*_*yer 5 obfuscation lua deobfuscation
我有一些我怀疑被混淆的 Lua 代码。我该如何去混淆它?
我相信代码被混淆了,因为它看起来与普通的 Lua 代码非常不同,但我知道它是有效的 Lua 代码,因为 Lua 解释器仍然会编译和运行代码。
我对去混淆代码有合法的兴趣,并且不打算违背作者的意愿分发它或修改它以规避任何 DRM 机制。
Lua源码的混淆一般有两种方式:
直接混淆代码,主要是通过重命名变量,引入牵引和重组代码,使其更难遵循
对源代码进行编码并将其作为字符串嵌入到 Lua 文件中,该文件只解码、加载和运行编码后的真实程序。
实际上,经常使用两者的组合:程序被混淆,然后编码并包装在一个字符串中。最后,加载和运行字符串的代码通常会再次混淆。
用于使 Lua 代码更难遵循的典型机制包括:
string.gsub,table.concat等一般来说,手动去混淆这些代码的步骤通常非常相似:重新格式化代码以使其更容易遵循控制流,然后弄清楚每个变量代表什么并重命名它们。为此,通常需要对语言有很好的理解,因为人们需要了解混淆所利用的所有规则,使代码更难理解。需要注意的一些此类规则:
getfenv和setfenv__index设置为string;.有关对特定 Lua 代码片段进行反混淆的详细帮助,您可以在以下其他在线社区中提问:
但记住:不要问,问就问
请注意,这些不是官方社区。有关更多选项,请参阅Lua 官方网站上的社区页面。