Il2CppDumper/README.zh-CN.md
2023-03-03 07:51:40 +08:00

3.8 KiB
Raw Blame History

Il2CppDumper

Build status

Unity il2cpp逆向工程

功能

  • 还原DLL文件不包含代码可用于提取MonoBehaviourMonoScript
  • 支持ELF, ELF64, Mach-O, PE, NSO和WASM格式
  • 支持Unity 5.3 - 2022.2
  • 生成IDA和Ghidra的脚本帮助IDA和Ghidra更好的分析il2cpp文件
  • 生成结构体头文件
  • 支持从内存dump的libil2cpp.so文件以绕过保护
  • 支持绕过简单的PE保护

使用说明

直接运行Il2CppDumper.exe并依次选择il2cpp的可执行文件和global-metadata.dat文件然后根据提示输入相应信息。

程序运行完成后将在当前运行目录下生成输出文件

命令行

Il2CppDumper.exe <executable-file> <global-metadata> <output-directory>

输出文件

DummyDll

文件夹包含所有还原的DLL文件

使用dnSpyILSpy或者其他.Net反编译工具即可查看具体信息

可用于提取Unity的MonoBehaviourMonoScript,适用于UtinyRipper或者UABE

ida.py

用于IDA

ida_with_struct.py

用于IDA, 读取il2cpp.h文件并在IDA中应用结构信息

il2cpp.h

包含结构体的头文件

ghidra.py

用于Ghidra

Il2CppBinaryNinja

用于BinaryNinja

ghidra_wasm.py

用于Ghidra, 和ghidra-wasm-plugin一起工作

script.json

用于IDA和Ghidra脚本

stringliteral.json

包含所有stringLiteral信息

关于config.json

  • DumpMethodDumpFieldDumpPropertyDumpAttributeDumpFieldOffset, DumpMethodOffset, DumpTypeDefIndex

    • 是否在dump.cs输出相应的内容
  • GenerateDummyDllGenerateScript

    • 是否生成这些内容
  • DummyDllAddToken

    • 是否在DummyDll中添加token
  • RequireAnyKey

    • 在程序结束时是否需要按键退出
  • ForceIl2CppVersionForceVersion

    • 当ForceIl2CppVersion为true程序将根据ForceVersion指定的版本读取il2cpp的可执行文件Metadata仍然使用header里的版本在部分低版本的il2cpp中可能会用到比如安卓20版本下你可能需要设置ForceVersion为16程序才能正常工作
  • ForceDump

    • 强制将文件视为dump文件
  • NoRedirectedPointer

    • 将dump文件中的指针视为未重定向的, 从某些设备dump出的文件需要设置该项为true

常见问题

ERROR: Metadata file supplied is not valid metadata file.

global-metadata.dat已被加密。关于解密的问题请去相关破解论坛寻求帮助请不要在issues提问

如果你的文件是libil2cpp.so并且你拥有一台已root的安卓手机你可以尝试我的另一个项目Zygisk-Il2CppDumper它能够无视global-metadata.dat加密

ERROR: Can't use auto mode to process file, try manual mode.

请注意PC平台的可执行文件是GameAssembly.dll或者*Assembly.dll

你可以打开一个新的issue并上传文件我会尝试解决

ERROR: This file may be protected.

Il2CppDumper检测到可执行文件已被保护使用GameGuardian从游戏内存中dump libil2cpp.so然后使用Il2CppDumper载入按提示操作可绕过大部分保护

如果你拥有一台已root的安卓手机你可以尝试我的另一个项目Zygisk-Il2CppDumper,它能够绕过几乎所有保护

感谢