一、说明

大概一两年前在《漏洞战争:软件漏洞分析精要》听到bindiff(和补丁比较法),但一直都没去使用。前两天再回头看书感觉需要使用一翻,整个过程下来还是遇到了一些问题,值得记录一番。

二、安装

2.1 jdk安装

bindiff是一款java程序,因此需要安装jdk,我装的是jdk1.8其他版本兼容性不太清楚。

jdk下载地址:https://www.oracle.com/technetwork/java/javase/downloads/index.html

2.2 ida安装

bindiff需要借助ida pro进行分析,所以需要安装ida pro。官方说明需要6.8及以上版本,但7.x版本也尚不支持。

ida pro安装可参考:https://www.cnblogs.com/lsdb/p/7500981.html

2.3 bindiff安装

下载地址:https://www.zynamics.com/software.html

bindiff同时支持windows、linux、mac;bindiff5只能装在win8和win10上;下载链接不明显但是是有链接的,直接中键点击文件名处即可下载。

双击运行安装程序

接受协议

选择安装组件和路径

指出自己ida pro安装的目录

确认安装

安装完成

三、bindiff使用

3.1 编写比较程序

我这里使用cfree创建两个控制台项目bindiff1和bindiff2,分另写入以下两分代码并各自编译。代码的区别就只是把if语句的大于号改为小于号。

bindff1代码:

# include <stdio.h>
int main(){
int a = ;
if (a > ){
printf("if brance\n");
}
else{
printf("else brance\n");
}
getchar();
}

bindff2代码:

# include <stdio.h>
int main(){
int a = ;
if (a < ){
printf("if brance\n");
}
else{
printf("else brance\n");
}
getchar();
}

3.2 使用ida创建数据库

bindiff不能直接分析exe程序,而只能先使用ida pro的.i64数据库基础上进行分析。

因此需要先用ida pro分别打开bindiff1.exe和bindiff2.exe再关闭,以创建.i64数据库。

3.3 bindiff载入文件并比较

到安装目录bin文件夹下双击bindiff.jar即可启动bindiff,界面如下:

主菜单----Diffs----New Diff

先后载入bindffi1.i64和bindiff2.i64,点击Diff进行比较

32位操作系统应该成功载入,64位操作系统可能会报错:“Can't find Diff engine at '...\differ64.exe'”

看意思是differ64.exe找不到,打开bindiff安装目录的bin文件夹,将bindiff.exe复制一份命名为bindiff64.exe,此时再重新载入比较即可。

Call Graph----两个文件的函数调用图

Matched Functions----两个文件的函数匹配度

Primary Unmatched Functions----

Secondary Unmatched Functions----

bindiff的主要简单使用是双击打开"Matched Functions"项,按相似度(Similarity)从低到高排序,相似度不为1的函数即为两个文件被改动的位置。

由上图可以看到,bindiff1.exe和bindiff2.exe只有_main相似度不为1,双击_main打开, 两个函数不同的位置会被以有底色形式标出

如下图可以看到只有一条指令不同:bindiff1.exe是"jle 0x401335"(小于等于则进入else)而bindiff2是“jg 0x401335”(大于则进入else)

由此我们可以推断出bindiff2.exe相对于bindiff1.exe做的改动是:bindiff1.exe是"if > else"而bindiff2.exe是"if < else"。与我们的改动完全一致。

3.4 将bindiff以ida插件形式使用

在上边的操作中我们需要先用ida打开文件创建数据库,再使用bindiff打开比较,这是比较麻烦的。bindiff允许直接以ida插件的形式使用。(在安装bindiff时已同步安装为插件所以不需要另行安装)

先使用ida打开bindiff1.exe,然后使用“Ctrl+6”打开窗口,如下图所示

点击“Diff Database...”载入bindiff2.i64。如下图,仍是类似单独使用时的那几个窗口。当然这只是简单查看比较最后还是要打开bindiff。

3.5 bindiff使用注意点

第一点,相同的高级语言代码使用不同编译器编译出来的内容是有区别的。比如我这里使用cfree编译,倘若同样的代码你用VC++去编译那函数数量可能会多不少。但当然识别出的改动位置还是一个意思的。

第二点,相同的高级语言代码使用相同编译器不同的编译模式编译出来的内容是有区别的。比如VC++优化模式和普通模式编译出的汇编代码是有区别的。

第三点,bindiff只能识别出汇编指令的区别不能识别出汇编指令操作数的区别。即如上边“jle 0x401335”和“jg 0x401335”会被不同底色标出,但如果是“jle 0x401335”和“jle 0x401336”那将不会被标出。

参考:

https://www.zynamics.com/bindiff/manual/index.html

BinDiff安装使用教程的更多相关文章

  1. IntelliJ IDEA - 热部署插件JRebel 安装使用教程

    IntelliJ IDEA - JRebel 安装使用教程 JRebel 能做什么? JRebel 是一款热部署插件.当你的 Java-web 项目在 tomcat 中 run/debug 的时候 , ...

  2. Zabbix3.x安装图解教程

    准备知识: Zabbix3.x比较之前的2.0界面有了很大的变化,但是安装部署过程与2.x基本完全一样. 1.Zabbix2.x安装图解教程 http://www.osyunwei.com/archi ...

  3. VMware vCenter Server安装图解教程

    安装说明: 1.安装VMware vCenter Server的主机操作系统为:Windows Server 2008 R2 2.在Windows Server 2008 R2中需要预先安装好SQL ...

  4. 在RedHat.Enterprise.Linux_v6.3系统中安装Oracle_11gR2教程

    在RedHat.Enterprise.Linux_v6.3系统中安装Oracle_11gR2教程 本教程提供PDF格式下载: 在RedHat.Enterprise.Linux_v6.3系统中安装Ora ...

  5. Zabbix安装图解教程

    说明: 操作系统:CentOS IP地址:192.168.21.127 Web环境:Nginx+MySQL+PHP zabbix版本:Zabbix 2.2 LTS 备注:Linux下安装zabbix需 ...

  6. MapGIS6.7安装图文教程(完美破解)

    mapgis安装比较简单,主要注意在安装的时候,先打开软件狗,然后再进行软件安装,一般就不会照成其他安装失败的现象,有时候安装之前没有打开软件狗也安装成功了,也有这情况,不过软件使用也需要软件狗的支持 ...

  7. VirtualBox安装Ubuntu教程

    1.VirtualBox虚拟机安装,及VirtualBox安装Ubuntu教程VirtualBox版本为VirtualBox-4.3.12-93733-Win.exe,Ubuntu版本为ubuntu- ...

  8. MySQL5.0版本的安装图解教程

    MySQL5.0版本的安装图解教程是给新手学习的,当前mysql5.0.96是最新的稳定版本. mysql 下载地址 http://www.jb51.net/softs/2193.html 下面的是M ...

  9. ENVI5.1安装破解教程

    原文地址:  ENVI5.1安装破解_百度经验 http://jingyan.baidu.com/article/020278118b5ded1bcd9ce57a.html   ENVI5.1_x86 ...

随机推荐

  1. 20175208 《Java程序设计》第八周学习总结

    20175208 2018-2019-3<Java程序设计>第八周学习总结 一.教材学习内容总结: 1.泛型: 泛型的主要目的是可以建立具有类型安全的集合框架(如链表.散列映射等数据结构) ...

  2. 2018-2019-2 《网络对抗技术》Exp3 免杀原理与实践 20165215

    目录 基础问题回答 (1)杀软是如何检测出恶意代码的? (2)免杀是做什么? (3)免杀的基本方法有哪些? 实践内容 任务一:正确使用msf编码器,msfvenom生成如jar之类的其他文件,veil ...

  3. 原 HTML5+规范:barcode(条码扫描)

    https://blog.csdn.net/qq_27626333/article/details/51815121 引用,版权归作者所有:

  4. DDL、DML和DCL的区别与理解

    DML.DDL.DCL区别 . 总体解释: DML(data manipulation language): 它们是SELECT.UPDATE.INSERT.DELETE,就象它的名字一样,这4条命令 ...

  5. 5.JAVA基础复习——JAVA中的static关键字作用与用法

    static关键字: 特点: 1.static是一个修饰符,用于修饰成员.(成员变量,成员函数)static修饰的成员变量 称之为静态变量或类变量. 2.static修饰的成员被所有的对象共享. 3. ...

  6. Java 新建excle文件并填充模版内容

    Java 新建excle文件并填充模版内容 一.JAR import java.io.BufferedReader; import java.io.File; import java.io.FileI ...

  7. 常用VIM插件配置

    airline 状态栏美化 除了airline本体还要下airline主题 和打过powerline补丁的字体 常用设置: set laststatus=2 " 总是显示状态栏 set no ...

  8. goldengate密码加密

    ----------------ogg加密GGSCI (ogghost) 10> encrypt password goldengate,ENCRYPTKEY defaultUsing defa ...

  9. layui 单选项 点击显示与隐藏

    同一个页面有多个单选按钮:https://blog.csdn.net/haibo0668/article/details/86220767

  10. 使用pynlpir增强jieba分词的准确度

    在使用jieba分词时,发现分词准确度不高.特别是一些专业词汇,比如堡垒机,只能分出堡垒,并不能分出堡垒机.这样导致的问题是很多时候检索并不准确. 经过对比测试,发现nlpir进行分词效果更好.但是n ...