| |
|
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
| -> 开发测试 -> AFL (American fuzzy lop) 二进制程序模糊测试工具学习 -> 正文阅读 |
|
|
[开发测试]AFL (American fuzzy lop) 二进制程序模糊测试工具学习 |
前言??在学习了一段时间的pwn后,我个人对漏洞挖掘也是充满了极大的兴趣,但是真实环境中的漏洞挖掘和CTF中的pwn题还是有很大区别的。原因在于,CTF中的pwn题代码量少,实现逻辑并不复杂,存在的漏洞也是比较明显的,一般都是通过代码审计就能发现;而在真实环境中,代码量大,实现逻辑复杂,虽然造成漏洞的代码可能和pwn题相差不大,但是在庞大的代码量下,通过代码审计的方式来发现漏洞并不是一个好的方式。因此,在工业界出现了fuzzing即模糊测试,其原理是变异输入来对程序进行测试,记录可以造成crash的输入,之后再单独分析这些输入。另外,对程序进行fuzzing来发现漏洞的软件叫fuzzer。 AFL的安装??AFL
AFL运行界面介绍??接下来看下AFL工作时的界面情况,如下截图所示,展示了AFL进行fuzzing时的工作界面状态。界面状态中的大部分内容都可以直接根据其中文意思知晓其含义,在本篇博客中将会简单介绍下大部分的状态指示。
fuzzing – 有源码的程序??接下来介绍AFL如何fuzzing有源码的程序。对于有源码的程序,先使用afl的编译器对源码进行插桩编译,编译c程序使用
??然后使用
??对于以文件作为输入的程序,可以使用下面的命令,直接在程序参数位置处使用
??以
??按照下面的命令操作进行,fuzz_out文件夹会在fuzzing时自动生成。
??如下截图所示,展示了fuzzing测试的结果,由于程序比较简单,在fuzzing几分钟后就已经发现了2个unique crashes,之所以要等半个小时,主要看看啥时候跑到蓝色指示轮数。
??最后我们重点关注的就是crashes下的测试用例,结合我们前面对代码的审计,只有一个栈溢出漏洞,那么这里产生的两个crash是怎么回事?如下截图所示,是两个测试用例的十六进制表示,其实都是栈溢出,只不过第一个用例首字母不是
fuzzing – 无源码的程序??待补充 总结不忘初心,砥砺前行! |
|
|
| 开发测试 最新文章 |
| pytest系列——allure之生成测试报告(Wind |
| 某大厂软件测试岗一面笔试题+二面问答题面试 |
| iperf 学习笔记 |
| 关于Python中使用selenium八大定位方法 |
| 【软件测试】为什么提升不了?8年测试总结再 |
| 软件测试复习 |
| PHP笔记-Smarty模板引擎的使用 |
| C++Test使用入门 |
| 【Java】单元测试 |
| Net core 3.x 获取客户端地址 |
|
|
| 上一篇文章 下一篇文章 查看所有文章 |
|
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
| 360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年12日历 | -2025/12/1 18:17:05- |
|
| 网站联系: qq:121756557 email:121756557@qq.com IT数码 |