• Dephi逆向工具Dede导出函数名MAP导入到IDA中


    1.背景

    在逆向Dephi程序时,会出现Dede软件可以看到函数的函数名,但是IDA逆向的时候看不到,为了解决这个问题,可以通过以下的方法来实现:

     2.基础知识

    IDA因为没有PDB文件,无法还原函数的原始名称,通过逆向工程师的汇编代码识别,可以给函数手工重新命名,也可以使用IDC脚本语言来给特定的地址命名:

    MakeName(0x006E624C, "TSingleForm.ComboBox1Change");

    基于这个原理,我们查找一下DEde如何生成这样的“地址:函数”的对应表。

    3.实操

    1.从Dede中导出地址函数表

    找到文件夹里的events.txt,这就是包含函数地址和函数名的文件。

    2.运行python脚本把events.txt转化为IDC脚本;

            以下的脚本打开脚本相同目录下的events.txt,用.split()方法把地址和函数名装入list[0]和list[1]中,无函数名的过滤掉。        

    1. import os
    2. try:
    3. import chardet
    4. except:
    5. os.system('pip install chardet')
    6. import chardet
    7. def check_charset(file_path):
    8. import chardet
    9. with open(file_path, "rb") as f:
    10. data = f.read(4)
    11. charset = chardet.detect(data)['encoding']
    12. return charset
    13. def map2idc(in_file, out_file):
    14. with open(out_file, 'w') as fout:
    15. fout.write('#include \n')
    16. fout.write('static main()\n{\n')
    17. with open(in_file,encoding=check_charset(in_file)) as fin:
    18. for line in fin:
    19. list = line.split()
    20. if len(list) == 2 and len(str(list[1])) == 8 and str(list[1]).isalnum():
    21. if(list[1][-4:]!=list[0][-4:]): #函数名==地址的,不要
    22. fout.write('\tMakeName(0x%s, "%s");\n' % (list[1], list[0]))
    23. fout.write('}\n')
    24. def main():
    25. return map2idc("./events.txt","./ida.idc")

            把上面的python复制到.py文件里,python脚本和events.txt放在同一个目录下,运行python脚本,就会生成ida.idc文件。一个简单的idc脚本如下:

    1. #include
    2. static main()
    3. {
    4. MakeName(0x0040178C, "TObject.System.GetSpace(Integer):TBlock;");
    5. }

    3.运行idc脚本,重命名函数

            打开Ida,File-->Script file,选择刚才生成的ida.idc文件,即可批量重命名函数了。

    这样,你的dehpi就有函数名了。

    4.总结

            通过这个脚本,我们就可以把专业dephi程序分析的结果,转移到IDA专业逆向代码分析的平台,实现联动。

     参考文献:把MAP文件导入IDA Pro的小程序 - sting feng - 博客园

  • 相关阅读:
    CnosDB有主复制演进历程
    golang 中的go指针
    YoC的使用
    第20章 原子操作实验(iTOP-RK3568开发板驱动开发指南 )
    手把手教你使用LabVIEW OpenCV dnn实现图像分类(含源码)
    Python+Requests+Pytest+Excel+Allure 接口自动化测试项目实战【框架之间的对比】
    Linux(1):开始
    算法金 | 决策树、随机森林、bagging、boosting、Adaboost、GBDT、XGBoost 算法大全
    bash: redi-cli: 未找到命令...
    Linux 最大可以打开多少文件描述符?
  • 原文地址:https://blog.csdn.net/qq_20031585/article/details/126122558