Il2CppDumper/README.md

106 lines
3.9 KiB
Markdown
Raw Normal View History

2016-12-30 15:29:45 -03:00
# Il2CppDumper
2017-04-11 03:37:13 -03:00
2018-03-05 02:29:53 -03: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-14 22:18:02 -03:00
2018-07-10 17:58:28 -04:00
中文说明请戳[这里](README.zh-CN.md)
2018-03-06 02:01:51 -03:00
Extract .NET metadata from il2cpp binaries. (types, methods, fields, etc.)
2018-03-05 02:29:53 -03:00
## Features
2019-04-11 21:17:29 -04:00
* Supports il2cpp binaries in ELF, ELF64, Mach-O, PE and NSO format
2019-01-09 15:55:08 -03:00
* Supports global-metadata version 16 and 19-24
2018-03-06 02:01:51 -03:00
* Extracts .NET metadata including types, fields, properties, methods and attributes
* Supports automated IDA script generation
2019-04-11 21:17:29 -04:00
* rename method
* name and tag metadata
2018-07-10 17:58:28 -04:00
* makefunction to improve ida analysis
2018-03-05 02:29:53 -03:00
* Generates dummy DLLs that can be viewed in .NET decompilers
## Usage
2019-11-06 09:15:03 -03:00
```
Il2CppDumper.exe <executable-file> <global-metadata> [unityVersion] [mode]
```
Or run `Il2CppDumper.exe` and choose the il2cpp executable file and `global-metadata.dat` file, then enter the information as prompted.
The program will then generate all the output files in current working directory.
2018-03-05 02:29:53 -03:00
### Extraction Modes
2017-10-25 18:30:24 -03:00
#### Manual
2018-03-05 02:29:53 -03:00
The parameters (`CodeRegistration` and `MetadataRegistration`) that are passed to `il2cpp::vm::MetadataCache::Register()` needs to be manually reverse engineered and passed to the program.
2019-11-06 09:15:03 -03:00
#### Auto - Obsolete
2018-03-05 02:29:53 -03:00
2019-11-06 09:15:03 -03:00
~~Automatically finds the `il2cpp_codegen_register()` function by signature matching and read out the first (`CodeRegistration`) and second (`MetadataRegistration`) parameter passed to the `il2cpp::vm::MetadataCache::Register()` method that will be invoked in the registration function. May not work well due to compiler optimizations.~~
2018-03-05 02:29:53 -03:00
#### Auto(Plus) - **Recommended**
2019-04-26 07:37:18 -04:00
Matches possible pointers in the data section with some guidance from global-metadata.
2018-03-05 02:29:53 -03:00
2019-08-31 14:59:13 -04:00
Supports metadata version 20 and up
2019-04-26 07:37:18 -04:00
only `CodeRegistration` address can be found on metadata version 16
2018-01-07 18:10:00 -03:00
#### Auto(Symbol)
2017-10-25 18:30:24 -03:00
2018-03-06 02:01:51 -03:00
Uses symbols in the il2cpp binary to locate `CodeRegistration` and `MetadataRegistration`.
2018-03-05 02:29:53 -03:00
2019-11-06 09:15:03 -03:00
Only supports ELF format file.
2018-03-05 02:29:53 -03:00
### Output files
#### dump.cs
C# pseudocode. Can be viewed in text editors (syntax highlighting recommended)
#### script.py
2017-10-25 18:30:24 -03:00
2018-03-06 02:01:51 -03:00
Requires IDA and IDAPython. Can be loaded in IDA via `File -> Script file`.
2017-10-25 18:30:24 -03:00
2019-11-06 09:15:03 -03:00
#### stringliteral.json
Contains all stringLiteral information
2018-03-05 02:29:53 -03:00
#### DummyDll
2018-01-04 04:45:10 -03:00
2019-11-06 09:15:03 -03:00
DLLs generated by Mono.Cecil which contain the .NET metadata extracted from the binary (no code included).
Can be used for deserialization of MonoBehaviour.
2017-10-25 18:30:24 -03:00
2018-03-05 02:29:53 -03:00
### Configuration
2018-01-07 18:10:00 -03:00
2018-03-05 02:29:53 -03:00
All the configuration options are located in `config.json`
2019-11-06 09:15:03 -03:00
2018-03-05 02:29:53 -03:00
Available options:
* `DumpMethod`, `DumpField`, `DumpProperty`, `DumpAttribute`, `DumpFieldOffset`, `DumpMethodOffset`, `DumpTypeDefIndex`
2018-03-06 02:01:51 -03:00
* Whether or not the program should extract these information
2018-03-05 02:29:53 -03:00
2018-03-06 02:01:51 -03:00
* `DummyDll`
* Whether or not the program should generate dummy DLLs
2018-03-05 02:29:53 -03:00
2019-11-06 09:15:03 -03:00
* `MakeFunction`
* Whether to add the MakeFunction code in script.py
2018-03-06 02:01:51 -03:00
* `ForceIl2CppVersion`, `ForceVersion`
* 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 ilcpp v20 (Android) binaries in order to work properly)
2018-03-05 02:29:53 -03:00
## Common errors
2017-11-03 06:14:59 -03:00
#### `ERROR: Metadata file supplied is not valid metadata file.`
2018-03-06 02:01:51 -03:00
The specified `global-metadata.dat` is invalid and the program cannot recognize it. 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.
2018-03-05 02:29:53 -03:00
#### `ERROR: Can't use this mode to process file, try another mode.`
Try other extraction modes.
2018-03-06 02:01:51 -03:00
If all automated extraction modes failed with this error and you are sure that the files you supplied are not corrupted/obfuscated, please file an issue with the logs and sample files.
2019-11-06 09:15:03 -03:00
## Credits
- Jumboperson - [Il2CppDumper](https://github.com/Jumboperson/Il2CppDumper)