2018-03-05 02:29:53 -03:00
|
|
|
|
# Il2CppDumper
|
2019-11-06 09:15:03 -03:00
|
|
|
|
|
|
|
|
|
[![Build status](https://ci.appveyor.com/api/projects/status/anhqw33vcpmp8ofa?svg=true)](https://ci.appveyor.com/project/Perfare/il2cppdumper/branch/master/artifacts)
|
|
|
|
|
|
2020-02-12 17:40:09 -03:00
|
|
|
|
Unity il2cpp逆向工程
|
2018-03-05 02:29:53 -03:00
|
|
|
|
|
|
|
|
|
## 功能
|
2020-02-12 17:40:09 -03:00
|
|
|
|
|
|
|
|
|
* 还原DLL文件(不包含代码),可用于提取`MonoBehaviour`和`MonoScript`
|
2020-04-09 22:55:34 -04:00
|
|
|
|
* 支持ELF, ELF64, Mach-O, PE, NSO和WASM格式
|
2023-03-02 20:51:40 -03:00
|
|
|
|
* 支持Unity 5.3 - 2022.2
|
2020-02-12 17:40:09 -03:00
|
|
|
|
* 生成IDA和Ghidra的脚本,帮助IDA和Ghidra更好的分析il2cpp文件
|
2020-04-09 22:55:34 -04:00
|
|
|
|
* 生成结构体头文件
|
2020-07-22 18:09:31 -04:00
|
|
|
|
* 支持从内存dump的`libil2cpp.so`文件以绕过保护
|
|
|
|
|
* 支持绕过简单的PE保护
|
2018-03-05 02:29:53 -03:00
|
|
|
|
|
|
|
|
|
## 使用说明
|
2019-11-06 09:15:03 -03:00
|
|
|
|
|
2020-02-12 17:40:09 -03:00
|
|
|
|
直接运行Il2CppDumper.exe并依次选择il2cpp的可执行文件和global-metadata.dat文件,然后根据提示输入相应信息。
|
|
|
|
|
|
|
|
|
|
程序运行完成后将在当前运行目录下生成输出文件
|
|
|
|
|
|
|
|
|
|
### 命令行
|
|
|
|
|
|
2019-11-06 09:15:03 -03:00
|
|
|
|
```
|
2020-06-20 11:15:57 -04:00
|
|
|
|
Il2CppDumper.exe <executable-file> <global-metadata> <output-directory>
|
2019-11-06 09:15:03 -03:00
|
|
|
|
```
|
|
|
|
|
|
2020-02-12 17:40:09 -03:00
|
|
|
|
### 输出文件
|
2019-04-26 07:37:18 -04:00
|
|
|
|
|
2020-02-12 17:40:09 -03:00
|
|
|
|
#### DummyDll
|
2019-04-26 07:37:18 -04:00
|
|
|
|
|
2020-02-12 17:40:09 -03:00
|
|
|
|
文件夹,包含所有还原的DLL文件
|
2019-04-26 07:37:18 -04:00
|
|
|
|
|
2020-02-12 17:40:09 -03:00
|
|
|
|
使用[dnSpy](https://github.com/0xd4d/dnSpy),[ILSpy](https://github.com/icsharpcode/ILSpy)或者其他.Net反编译工具即可查看具体信息
|
2018-03-05 02:29:53 -03:00
|
|
|
|
|
2020-02-12 17:40:09 -03:00
|
|
|
|
可用于提取Unity的`MonoBehaviour`和`MonoScript`,适用于[UtinyRipper](https://github.com/mafaca/UtinyRipper)或者[UABE](https://7daystodie.com/forums/showthread.php?22675-Unity-Assets-Bundle-Extractor)等
|
|
|
|
|
|
|
|
|
|
#### ida.py
|
2019-11-06 09:15:03 -03:00
|
|
|
|
|
2020-02-12 17:40:09 -03:00
|
|
|
|
用于IDA
|
2018-03-05 02:29:53 -03:00
|
|
|
|
|
2020-02-27 07:57:34 -03:00
|
|
|
|
#### ida_with_struct.py
|
|
|
|
|
|
|
|
|
|
用于IDA, 读取il2cpp.h文件并在IDA中应用结构信息
|
|
|
|
|
|
|
|
|
|
#### il2cpp.h
|
|
|
|
|
|
|
|
|
|
包含结构体的头文件
|
|
|
|
|
|
2020-02-12 17:40:09 -03:00
|
|
|
|
#### ghidra.py
|
|
|
|
|
|
|
|
|
|
用于Ghidra
|
2018-03-05 02:29:53 -03:00
|
|
|
|
|
2022-06-09 13:19:49 -04:00
|
|
|
|
#### Il2CppBinaryNinja
|
2022-03-18 18:27:16 -03:00
|
|
|
|
|
|
|
|
|
用于BinaryNinja
|
|
|
|
|
|
2021-12-05 20:08:36 -03:00
|
|
|
|
#### ghidra_wasm.py
|
|
|
|
|
|
|
|
|
|
用于Ghidra, 和[ghidra-wasm-plugin](https://github.com/nneonneo/ghidra-wasm-plugin)一起工作
|
|
|
|
|
|
2020-02-22 15:31:34 -03:00
|
|
|
|
#### script.json
|
|
|
|
|
|
|
|
|
|
用于IDA和Ghidra脚本
|
|
|
|
|
|
2019-11-06 09:15:03 -03:00
|
|
|
|
#### stringliteral.json
|
|
|
|
|
|
2020-02-12 17:40:09 -03:00
|
|
|
|
包含所有stringLiteral信息
|
2018-03-05 02:29:53 -03:00
|
|
|
|
|
|
|
|
|
### 关于config.json
|
2020-02-12 17:40:09 -03:00
|
|
|
|
|
2019-11-06 09:15:03 -03:00
|
|
|
|
* `DumpMethod`,`DumpField`,`DumpProperty`,`DumpAttribute`,`DumpFieldOffset`, `DumpMethodOffset`, `DumpTypeDefIndex`
|
|
|
|
|
* 是否在dump.cs输出相应的内容
|
2018-03-05 02:29:53 -03:00
|
|
|
|
|
2020-06-20 11:15:57 -04:00
|
|
|
|
* `GenerateDummyDll`,`GenerateScript`
|
|
|
|
|
* 是否生成这些内容
|
2019-11-06 09:15:03 -03:00
|
|
|
|
|
2022-04-21 21:46:31 -04:00
|
|
|
|
* `DummyDllAddToken`
|
|
|
|
|
* 是否在DummyDll中添加token
|
|
|
|
|
|
|
|
|
|
* `RequireAnyKey`
|
|
|
|
|
* 在程序结束时是否需要按键退出
|
|
|
|
|
|
2019-11-06 09:15:03 -03:00
|
|
|
|
* `ForceIl2CppVersion`,`ForceVersion`
|
2022-04-21 21:46:31 -04:00
|
|
|
|
* 当ForceIl2CppVersion为`true`时,程序将根据ForceVersion指定的版本读取il2cpp的可执行文件(Metadata仍然使用header里的版本),在部分低版本的il2cpp中可能会用到(比如安卓20版本下,你可能需要设置ForceVersion为16程序才能正常工作)
|
|
|
|
|
|
|
|
|
|
* `ForceDump`
|
|
|
|
|
* 强制将文件视为dump文件
|
|
|
|
|
|
|
|
|
|
* `NoRedirectedPointer`
|
|
|
|
|
* 将dump文件中的指针视为未重定向的, 从某些设备dump出的文件需要设置该项为`true`
|
2018-03-05 02:29:53 -03:00
|
|
|
|
|
|
|
|
|
## 常见问题
|
2020-02-12 17:40:09 -03:00
|
|
|
|
|
2019-11-06 09:15:03 -03:00
|
|
|
|
#### `ERROR: Metadata file supplied is not valid metadata file.`
|
2018-03-05 02:29:53 -03:00
|
|
|
|
|
2020-02-12 17:40:09 -03:00
|
|
|
|
global-metadata.dat已被加密。关于解密的问题请去相关破解论坛寻求帮助,请不要在issues提问!
|
|
|
|
|
|
2022-04-21 21:51:48 -04:00
|
|
|
|
如果你的文件是`libil2cpp.so`并且你拥有一台已root的安卓手机,你可以尝试我的另一个项目[Zygisk-Il2CppDumper](https://github.com/Perfare/Zygisk-Il2CppDumper),它能够无视global-metadata.dat加密
|
2020-07-22 18:09:31 -04:00
|
|
|
|
|
2020-02-12 17:40:09 -03:00
|
|
|
|
#### `ERROR: Can't use auto mode to process file, try manual mode.`
|
|
|
|
|
|
2020-07-22 18:09:31 -04:00
|
|
|
|
请注意PC平台的可执行文件是`GameAssembly.dll`或者`*Assembly.dll`
|
|
|
|
|
|
|
|
|
|
你可以打开一个新的issue,并上传文件,我会尝试解决
|
2020-02-12 17:40:09 -03:00
|
|
|
|
|
|
|
|
|
#### `ERROR: This file may be protected.`
|
|
|
|
|
|
2020-07-22 18:09:31 -04:00
|
|
|
|
Il2CppDumper检测到可执行文件已被保护,使用`GameGuardian`从游戏内存中dump `libil2cpp.so`,然后使用Il2CppDumper载入按提示操作,可绕过大部分保护
|
|
|
|
|
|
2022-04-21 21:51:48 -04:00
|
|
|
|
如果你拥有一台已root的安卓手机,你可以尝试我的另一个项目[Zygisk-Il2CppDumper](https://github.com/Perfare/Zygisk-Il2CppDumper),它能够绕过几乎所有保护
|
2019-11-06 09:15:03 -03:00
|
|
|
|
|
|
|
|
|
## 感谢
|
2020-02-12 17:40:09 -03:00
|
|
|
|
|
2022-06-09 13:19:49 -04:00
|
|
|
|
- Jumboperson - [Il2CppDumper](https://github.com/Jumboperson/Il2CppDumper)
|