-
Notifications
You must be signed in to change notification settings - Fork 15
/
Copy pathdump_dex.js
119 lines (106 loc) · 5.86 KB
/
dump_dex.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
// dumpdex
// dump dex use on command line
// cmd:
// $ frida -U -f packagename -l dexcl.js --no-pause
// such as:
//$ frida -U -f com.example.hello -l dexcl.js --no-pause
if(Java.available) {
Java.perform(function () {
// my 5.02 libart.so -> DefineClass
// art::ClassLinker::DefineClass(
// art::Thread *,
// char const*,
// uint,
// art::Handle<art::mirror::ClassLoader>,
// art::DexFile const&,
// art::DexFile::ClassDef const&)
// 5.02 export sym
// _ZN3art11ClassLinker11DefineClassEPNS_6ThreadEPKcjNS_6HandleINS_6mirror11ClassLoaderEEERKNS_7DexFileERKNS9_8ClassDefE
// you should change next line for your android version
var defineClass = Module.findExportByName("libart.so", "_ZN3art11ClassLinker11DefineClassEPNS_6ThreadEPKcjNS_6HandleINS_6mirror11ClassLoaderEEERKNS_7DexFileERKNS9_8ClassDefE");
// you should change up line for your android version
console.log("[*] define class addr: " + defineClass);
Interceptor.attach(defineClass, {
onEnter: function (args) {
var classname = args[2].readUtf8String();
//找到目标相关类
//console.log("[+] class name: " + classname);
if(classname == "Lcom/qihoo/sdk/report/d/a;") { // 修改相关类
console.log("[+] class name: " + classname);
console.log("[*] this obj addr: " + args[0]); // this
console.log("[*] thread addr: " + args[1]); // thread
console.log("[*] classname addr: " + args[2]); // classname
console.log("[*] uint value: " + args[3]); // unit
console.log("[*] classloader addr: " + args[4]); // classloader
console.log("[*] dex file: " + args[5]); // dex_file
console.log("[*] dex classdef addr: " + args[6]); // dex_class_def
// struct Header {
// unsigned char magic_[8];
// unsigned int checksum_; // See also location_checksum_
// unsigned char signature_[20];
// unsigned int file_size_; // size of entire file
// unsigned int header_size_; // offset to start of next section
// unsigned int endian_tag_;
// unsigned int link_size_; // unused
// unsigned int link_off_; // unused
// unsigned int map_off_; // unused
// unsigned int string_ids_size_; // number of StringIds
// unsigned int string_ids_off_; // file offset of StringIds array
// unsigned int type_ids_size_; // number of TypeIds, we don't support more than 65535
// unsigned int type_ids_off_; // file offset of TypeIds array
// unsigned int proto_ids_size_; // number of ProtoIds, we don't support more than 65535
// unsigned int proto_ids_off_; // file offset of ProtoIds array
// unsigned int field_ids_size_; // number of FieldIds
// unsigned int field_ids_off_; // file offset of FieldIds array
// unsigned int method_ids_size_; // number of MethodIds
// unsigned int method_ids_off_; // file offset of MethodIds array
// unsigned int class_defs_size_; // number of ClassDefs
// unsigned int class_defs_off_; // file offset of ClassDef array
// unsigned int data_size_; // unused
// unsigned int data_off_; // unused
// };
// args[5] == art::DexFile
// DexFile + 0 = vtable addr
// DexFile + 4 = *begin_ = *DexHeader
var dex_begin = args[5].toInt32() + 4; // *begin
var dp = Memory.readUInt(ptr(dex_begin)) // real memaddr
console.log(Memory.readByteArray(ptr(dp), 16));
var fsize = Memory.readUInt(ptr(dp + 32));
console.log("dex file size : " + fsize); // fileSize
console.log("[+] begin to dump dex ...");
// console.log(hexdump(ptr(dp), {
// offset: 0,
// length: fsize,
// header: true,
// ansi: true
// }));
var mapx_buf_len = 10240;
var i = 0;
var count = parseInt(fsize / mapx_buf_len);
var lastbuf_len = parseInt(fsize % mapx_buf_len);
if (lastbuf_len > 0) {
count += 1;
}
console.log("[+] send count: " + count);
console.log("[+] send lastbuf_len: " + lastbuf_len);
//保存在应用目录下
var file = new File("/data/data/com.qihoo.srouter.n300/files/dumpdex.dex","wb");
for (; i < count ; i++) {
if ((lastbuf_len > 0) && (i == (count - 1))) {
console.log("[*] mem off: " + i*mapx_buf_len);
console.log("[*] mem last off: " + lastbuf_len);
file.write(Memory.readByteArray(ptr(dp + i*mapx_buf_len) , lastbuf_len));
//send("Send dex file", Memory.readByteArray(ptr(dp + i*mapx_buf_len) , lastbuf_len));
} else {
console.log("[*] mem off: " + i*mapx_buf_len);
//send("Send dex file", Memory.readByteArray(ptr(dp + i*mapx_buf_len) , mapx_buf_len));
file.write(Memory.readByteArray(ptr(dp + i*mapx_buf_len) , mapx_buf_len))
}
}
file.close()
console.log("[+] finish to dump dex .../data/data/com.qihoo.srouter.n300/files/dumpdex.dex");
}
}
});
});
}