首页 > 其他 > 详细

一个dumpdex的IDA插件

时间:2014-10-05 14:33:38      阅读:323      评论:0      收藏:0      [点我收藏+]

一个DumpDex的IDA插件

源码

import idaapi
import struct


def dumpdex(start, len, target):
 rawdex = idaapi.dbg_read_memory(start, len)
 fd = open(target, ‘wb‘)
 fd.write(rawdex)
 fd.close()

def getdexlen(start):
 pos = start + 0x20
 mem = idaapi.dbg_read_memory(pos, 4)
 len = struct.unpack(‘<I‘, mem)[0]
 print ‘len is ‘ + str(hex(len))
 return int(len)


start = AskAddr(0, ‘Input DexFile start in hex: ‘)
print(‘start is ‘ + str(hex(start)))


len = AskLong(getdexlen(start), ‘Input DexFile len in hex: ‘)
target = AskStr(‘/users/boyliang/temp/xx.dex‘, ‘Input the dump file path‘)


if len > 0 and start > 0x0 and target and AskYN(1, ‘start is 0x%0x, len is %d, dump to %s‘ % (start, len, target)) == 1:
 dumpdex(start, len, target)
 print(‘Dump Finish‘)

用法

  • 首先shift + f2,调出IDA,选择import,把本脚本导入
  • 当动态调试的时候,找到dex的始址,比如断点在dvmDexFileOpenPartial,r0即是dex的始址
  • shift + f2,调出脚本,选择本脚本,按UI提示输入即可

注意: 这个小插件目前只支持连续的Dex文件,非连续性的不支持

一个dumpdex的IDA插件

原文:http://blog.csdn.net/l173864930/article/details/39802801

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!