DexRewrite 是一个针对Android dex文件分析、解析、重构的 C++ 库
- 使用 Android Studio 和 Cmake编译
- 使用 Jetbrains Clion 和 Cmake编译
- 解析整个dex文件。
- 统计字符串、函数、字段引用。
- 反编译指定函数
- Android隐藏API调用扫描
- Dex文件合并(已完成,测试中,待开源)
- Dex ASM汇编支持(已经完成、测试中,待开源)
- Dex文件合并后,各个索引值排序问题
- ASM 框架插入代码 goto、goto/16、goto/32 跳转存在问题
相关使用可以参考 main.cpp repairdex.cpp文件
遍历整个dex文件中的所有类
for (const auto &class_data : mHeader->ClassDatas()) {
const char *class_name = class_data->GetClassDef()->ClassType()->GetStringId()->Data();
for (auto &direct_method : *class_data.get()->DirectMethods()) {
repairNopCode(direct_method->GetCodeItem());
}
for (auto &virtual_method: *class_data.get()->VirtualMethods()) {
repairNopCode(virtual_method->GetCodeItem());
}
}
遍历dex文件中所有函数实体
for (const auto &class_data : mHeader->ClassDatas()) {
for (auto &direct_method : *class_data.get()->DirectMethods()) {
repairNopCode(direct_method->GetCodeItem());
}
for (auto &virtual_method: *class_data.get()->VirtualMethods()) {
repairNopCode(virtual_method->GetCodeItem());
}
}
或者
for (const auto &methodItem : mHeader->MethodItems()) {
auto index = methodItem.first;
auto method_item = methodItem.second;
}
遍历所有Dex文件中的Codeitem实体
for (const auto &codeItem : mHeader->CodeItems()) {
}
将dex文件输出到文件
dex_ir::DexWriter::Output(mHeader.get(), "out.dex");
致力于脱离Java环境,实现一套可以对Dex文件反编译、字节码编译的框架。开源版本目前仅限于重写Dex文件、反编译Dex文件。
至于DexASM 和 DexMerger 相关代码已经实现,正在测试中,目前用于公司产品上,稳定后将会开源。
https://android.googlesource.com/platform/art/+/master/dexlayout/
https://android.googlesource.com/platform/art/+/refs/heads/master/libdexfile/