2016-12-31 02:29:45 +08:00
# Il2CppDumper
2017-04-11 14:37:13 +08:00
2018-03-05 01:29:53 -04:00
[![Build status ](https://ci.appveyor.com/api/projects/status/anhqw33vcpmp8ofa?svg=true )](https://ci.appveyor.com/project/Perfare/il2cppdumper/branch/master/artifacts)
2017-04-15 09:18:02 +08:00
2018-07-11 05:58:28 +08:00
中文说明请戳[这里 ](README.zh-CN.md )
2020-02-13 04:40:09 +08:00
Unity il2cpp reverse engineer
2018-03-05 01:29:53 -04:00
## Features
2020-02-13 04:40:09 +08:00
* Complete DLL restore (except code), can be used to extract `MonoBehaviour` and `MonoScript`
2019-11-15 08:43:52 +08:00
* Supports ELF, ELF64, Mach-O, PE and NSO format
2020-02-13 04:40:09 +08:00
* Supports Unity 5.3 - 2020
* Supports generate IDA and Ghidra scripts to help IDA and Ghidra better analyze il2cpp files
* Supports Android memory dumped `libil2cpp.so` file to bypass 99% protection
2018-03-05 01:29:53 -04:00
## Usage
2020-02-13 04:40:09 +08:00
Run `Il2CppDumper.exe` and choose the il2cpp executable file and `global-metadata.dat` file, then enter the information as prompted
2018-03-05 01:29:53 -04:00
2020-02-13 04:40:09 +08:00
The program will then generate all the output files in current working directory
2017-10-26 05:30:24 +08:00
2020-02-13 04:40:09 +08:00
### Command-line
2018-03-05 01:29:53 -04:00
2020-02-13 04:40:09 +08:00
```
2020-02-26 02:04:13 +08:00
Il2CppDumper.exe < executable-file > < global-metadata >
2020-02-13 04:40:09 +08:00
```
2018-03-05 01:29:53 -04:00
2020-02-13 04:40:09 +08:00
### Outputs
2019-04-26 19:37:18 +08:00
2020-02-13 04:40:09 +08:00
#### DummyDll
2017-10-26 05:30:24 +08:00
2020-02-13 04:40:09 +08:00
Folder, containing all restored dll files
2018-03-05 01:29:53 -04:00
2020-02-13 04:40:09 +08:00
Use [dnSpy ](https://github.com/0xd4d/dnSpy ), [ILSpy ](https://github.com/icsharpcode/ILSpy ) or other .Net decompiler tools to view
2018-03-05 01:29:53 -04:00
2020-02-13 04:40:09 +08:00
Can be used to extract Unity `MonoBehaviour` and `MonoScript` , for [UtinyRipper ](https://github.com/mafaca/UtinyRipper ), [UABE ](https://7daystodie.com/forums/showthread.php?22675-Unity-Assets-Bundle-Extractor )
2018-03-05 01:29:53 -04:00
2020-02-13 04:40:09 +08:00
#### ida.py
2018-03-05 01:29:53 -04:00
2020-02-13 04:40:09 +08:00
For IDA
2018-03-05 01:29:53 -04:00
2020-02-27 18:57:34 +08:00
#### ida_with_struct.py
For IDA, read il2cpp.h file and apply structure information in IDA
#### il2cpp.h
structure information header file
2020-02-13 04:40:09 +08:00
#### ghidra.py
2017-10-26 05:30:24 +08:00
2020-02-13 04:40:09 +08:00
For Ghidra
2017-10-26 05:30:24 +08:00
2020-02-23 02:31:34 +08:00
#### script.json
For ida.py and ghidra.py
2019-11-06 20:15:03 +08:00
#### stringliteral.json
Contains all stringLiteral information
2018-03-05 01:29:53 -04:00
### Configuration
2018-01-08 05:10:00 +08:00
2018-03-05 01:29:53 -04:00
All the configuration options are located in `config.json`
2019-11-06 20:15:03 +08:00
2018-03-05 01:29:53 -04:00
Available options:
2018-12-17 21:55:46 -05:00
* `DumpMethod` , `DumpField` , `DumpProperty` , `DumpAttribute` , `DumpFieldOffset` , `DumpMethodOffset` , `DumpTypeDefIndex`
2019-11-15 08:43:52 +08:00
* Whether to output these information to dump.cs
2018-03-05 01:29:53 -04:00
2018-03-06 01:01:51 -04:00
* `DummyDll`
2019-11-15 08:43:52 +08:00
* Whether to generate dummy DLLs
2018-03-05 01:29:53 -04:00
2019-11-06 20:15:03 +08:00
* `MakeFunction`
2020-02-26 02:03:23 +08:00
* Whether to add the MakeFunction code in script.json
2019-11-06 20:15:03 +08:00
2018-03-06 01:01:51 -04:00
* `ForceIl2CppVersion` , `ForceVersion`
2019-11-15 08:43:52 +08:00
* If `ForceIl2CppVersion` is `true` , the program will use the version number specified in `ForceVersion` to choose parser for il2cpp binaries (does not affect the choice of metadata parser). This may be useful on some older il2cpp version (e.g. the program may need to use v16 parser on il2cpp v20 (Android) binaries in order to work properly)
2018-03-05 01:29:53 -04:00
## Common errors
2017-11-03 17:14:59 +08:00
#### `ERROR: Metadata file supplied is not valid metadata file.`
2020-02-13 04:40:09 +08:00
Make sure you choose the correct file. Sometimes games may obfuscate this file for content protection purposes and so on. Deobfuscating of such files is beyond the scope of this program, so please **DO NOT** file an issue regarding to deobfuscating.
#### `ERROR: Can't use auto mode to process file, try manual mode.`
2018-03-05 01:29:53 -04:00
2020-02-13 04:40:09 +08:00
Make sure the executable is not protected, you can open a new issue and upload the file, I will try to solve.
2018-03-05 01:29:53 -04:00
2020-02-13 04:40:09 +08:00
#### `ERROR: This file may be protected.`
2018-03-05 01:29:53 -04:00
2020-02-13 04:40:09 +08:00
Il2CppDumper detected that the executable file has been protected, use `GameGuardian` to dump `libil2cpp.so` from the game memory, then use Il2CppDumper to load and follow the prompts, can bypass 99% protection
2019-11-06 20:15:03 +08:00
## Credits
- Jumboperson - [Il2CppDumper ](https://github.com/Jumboperson/Il2CppDumper )