Fuzz测试:发现软件隐患和漏洞的秘密武器
0x01 什么是模糊测试
模糊测试(Fuzz Testing)是一种广泛用于软件安全和质量测试的自动化测试方法。它的基本思想是向输入参数或数据中注入随机、不规则或异常的数据,以检测目标程序或系统在处理不合法、不正常或边缘情况下的行为。模糊测试通常用于寻找软件漏洞、安全漏洞和崩溃点,以改进软件的稳定性和安全性。
0x02 基本原理和组成
1.基本原理
基本思想
模糊测试的思想是构造所有可能的输入,并将输入传递给被测目标程序,然后监控目标程序在接收输入后是否出现异常情况,以此来发现软件中存在的缺陷和故障。
构造输入 -> 输入 -> 监控状态 -> 判断异常 -> 报告
抓住了大程序开发的痛点,一定程度上提升了安全测试的效率。
基本概念
其中内容加粗体的属于概念。在此我用简单的话语诠释其中的关系。
给一个简单的图阐释关系,可以配合文字理解。
模糊测试通常包括模糊测试实例,而模糊测试实例包括了两个重要元素:数据集合和程序执行路径。
数据集合即输入数据的集合,程序执行路径指的是程序指令序列和对应的内存和寄存器状态。
帮助网安学习,全套资料S信免费领取:
① 网安学习成长路径思维导图
② 60+网安经典常用工具包
③ 100+SRC分析报告
④ 150+网安攻防实战技术电子书
⑤ 最权威CISSP 认证考试指南+题库
⑥ 超1800页CTF实战技巧手册
⑦ 最新网安大厂面试题合集(含答案)
⑧ APP客户端安全检测指南(安卓+IOS)
我们再分开谈谈数据集合和程序执行路径。
数据集合的元素由数据组成,数据包括数据的取值和输入条件(网络输出或窗口输出)。
程序执行路径由执行状态和执行状态的支配关系组成。执行状态包括了二进制指令(比如此时是mov rax,1
)和内存与寄存器状态的集合(比如此时rbx = 0, rcx = 1
……内存中0x404080 = '\x90'
)。支配关系指的是下一个到哪里,条件判断等等。
套娃结束了,接下来就是程序异常、异常执行路径,等价执行路径,测试用例集合,测试用例序号,异常测试用例,等价测试用例。
-
程序异常:程序异常是在程序执行过程中出现的不正常行为,通常导致程序崩溃、错误或漏洞暴露。模糊测试的目标之一是发现程序异常。
-
异常执行路径:异常执行路径是程序在异常情况下的执行路径,它包括了导致异常的条件和操作序列。模糊测试可以通过检测异常执行路径来发现潜在的漏洞。
-
等价执行路径:等价执行路径是指在不同输入情况下,程序可能会采取相似或等效的执行路径。理解等价执行路径有助于减少测试用例的冗余。
-
测试用例集合:测试用例集合包含了多个测试用例,每个测试用例都是一个输入数据和对应的测试条件的组合。模糊测试通常会生成大量的测试用例,以检测各种可能的情况。
-
测试用例序号:测试用例序号是测试用例在测试用例集合中的唯一标识,用于跟踪和管理测试进度和结果。
-
异常测试用例(Exception Test Case):
- 异常测试用例是用于测试软件系统如何处理异常情况的测试实例。
- 这些异常情况可能包括输入无效数据、越界访问、不合法的操作、资源不足等。
- 目标是验证软件是否能够优雅地处理这些异常,而不会导致崩溃或不正常行为。
- 例如,一个异常测试用例可能是尝试输入一个非数字字符到一个要求输入数字的字段中,以测试程序是否能够捕获和处理这种非法输入。
-
等价测试用例(Equivalence Test Case):
- 等价测试用例是用于测试软件系统在不同输入情况下是否表现相似或等效的测试实例。
- 这些测试用例通常分为等效类别,每个等效类别代表一组具有相似特征的输入数据。
- 目标是在每个等效类别中选择一个或多个测试用例,以代表该类别的所有可能输入情况。
- 通过这种方式,测试用例集合可以更全面地覆盖各种输入情况,而不必测试每个可能的输入。
- 例如,对于一个登录功能,等价测试用例可以包括一个有效的用户名和密码组合、一个无效的用户名和有效的密码组合,以及一个有效的用户名和无效的密码组合,以代表不同的等效类别。
简单说,测试用例是用于测试软件系统的具体实例,异常测试用例用于验证异常情况的处理,而等价测试用例用于覆盖不同等效类别的输入情况,以确保软件在各种情况下都能正确运行。有效的测试用例设计是软件测试的关键,它有助于发现潜在问题并提高软件的质量。
2.系统组成
模糊测试分为测试数据生成,数据交互与控制,测试结果反馈三个阶段。
测试数据生成
->数据交互与控制
->测试结果反馈
根据这些过程,对应着模糊测试一般分为三个模块:数据生成模块
,环境控制模块
和状态监控模块
。
模糊测试通常分为三个关键模块,即数据生成模块、环境控制模块和状态监控模块。这些模块在模糊测试中起着不同但关键的作用:
-
数据生成模块:
-
用途:数据生成模块的主要目标是生成模糊测试用例,这些测试用例将用作目标程序或系统的输入。这些测试用例通常包括各种异常、不合法或随机的数据,以检测程序在面对不正常输入时的反应。
-
方法:数据生成模块可以使用多种技术来创建测试用例,包括但不限于以下几种:
-
随机生成:生成随机数据,包括字符、数字、二进制数据等。
-
模式匹配:根据已知的数据模式或协议规范生成数据。例如,HTTP请求中的URL、参数和头部可以按照HTTP协议规范生成。
-
变异:基于已有的有效输入,通过添加、删除或修改数据的方式来生成测试用例,使其变得不正常或异常。
-
基于语法的生成:使用语法规则来生成数据,确保生成的数据符合语法结构,如JSON、XML等。
-
-
-
环境控制模块:
-
用途:环境控制模块负责模拟测试环境,包括目标程序的运行环境以及可能的外部条件,如网络、文件系统等。它确保模糊测试过程中的环境是可控制和可复制的。
-
方法:环境控制模块可以采用以下方法来实现环境模拟和控制:
-
虚拟化:在虚拟环境中运行目标程序,以隔离测试过程,确保系统稳定性和安全性。
-
模拟网络环境:模拟不同网络条件,如高延迟、丢包等,以测试程序在不同网络条件下的表现。
-
文件系统操作:模拟文件操作,包括文件创建、删除、修改等,以测试程序对文件操作的鲁棒性。
-
资源限制:限制CPU、内存和网络带宽等资源,以模拟资源受限的情况。
-
-
-
状态监控模块:
-
用途:状态监控模块用于监视目标程序的执行状态和异常情况。它捕获程序的行为,包括崩溃、错误、异常输出等,并将这些信息用于后续的分析和报告。
-
方法:状态监控模块可以采用以下方法来监控目标程序的状态:
-
日志记录:记录程序的输出、错误消息和运行时信息,以便后续分析。
-
异常检测:监测程序是否发生崩溃或异常,例如,通过监视进程是否终止或产生错误代码。
-
内存分析:检查程序的内存使用情况,以发现内存泄漏或非法内存访问。
-
性能分析:监控程序的性能指标,如响应时间、CPU利用率等,以评估程序的性能稳定性。
-
-
鲁棒性(Robustness)是计算机科学和软件工程领域的一个重要概念,它指的是系统或软件在面对异常或不正常输入、外部条件或行为时能够保持稳定性和可靠性的能力。
值得一提:有关状态监控模块的处理
状态监控模块在捕获异常时需要对测试对象异常的三种情况进行分别处理:
- 被测试对象内置的异常处理流程捕获的异常:这种异常情况是指目标程序或系统能够识别和捕获异常,并按照其内置的异常处理流程来处理。这些异常通常不会导致程序崩溃,因为它们得到了适当的处理。这类异常情况通常不会揭示漏洞,因为程序已经处理了异常情况。
- 无法被测试对象内置的异常处理捕获的,但因异常被中断执行的异常:这种异常情况是指目标程序或系统无法正确捕获或处理异常,但异常的出现导致了程序的中断或崩溃。尽管程序崩溃,但这些异常情况通常具有更高的价值,因为它们表明存在漏洞或错误,可能需要进行修复。
- 无法被测试对象内置的异常处理捕获的,但异常不被中断执行,导致非预期的结果的异常:这种异常情况是指异常没有导致程序的崩溃,但却引发了程序内部的非预期行为或错误结果。这类异常情况同样具有较高的价值,因为它们可能揭示了潜在的漏洞或问题,尤其是在用户体验和系统可靠性方面。
其中,后两种异常情况更有价值,因为它们通常指示了潜在的漏洞或问题,这些问题可能需要开发人员的关注和修复,以提高系统的鲁棒性和稳定性。模糊测试的目标之一就是发现并报告这些异常情况,以帮助改进软件的质量。
0x03 基础方法技术
数据生成方法
1.基本类型数据生成方法
- 预定义序列:
- 经验数据:经验数据是基于先前的测试经验或实际使用中的数据样本来定义的。它们通常反映了一组合理的、常见的或已知的输入值。经验数据有助于测试基础功能,确保软件在正常情况下运行。例如,对于一个登录页面,经验数据可能包括一组有效的用户名和密码组合。
- 特别数据:特别数据是为了测试特定边界条件或较少常见情况而定义的数据。这些数据通常不符合常规输入,但可能会揭示潜在问题。例如,测试一个计算器应用程序时,特别数据可能包括除以零的情况。
- 随机数序列:
- 随机数序列是根据随机性生成的一系列数字。它们广泛用于模糊测试,因为它们可以模拟未知或不可预测的输入情况。随机数序列可以包括整数、浮点数或其他数字类型。
- 随机数生成器可以根据不同的分布(如均匀分布、正态分布等)生成随机数。在模糊测试中,可以指定随机数的范围和分布来控制生成的数据。
- 小数值覆盖大数值:
- 这是一种测试策略,其中测试用例倾向于包括较小的数值,以测试系统对较小值的处理。这是因为较小的值可能更容易导致不正常行为,如除以零或下溢。
- 例如,在测试一个计算器应用程序时,可以生成一系列小于1的随机浮点数来检查除法操作的鲁棒性。
2.复合类型数据生成方法
文件、网络数据包分别按照文件格式网络协议格式将基本类型数据组合成符合类型数据。
- 文件生成:
- 对于文本文件,可以创建一个文本文件对象,然后将字符串数据写入文件。在不同的编程语言中,有文件写入和操作的库和函数可供使用。
- 对于二进制文件,可以使用二进制文件的格式规范来构建文件头和内容部分,然后将它们写入文件。
- 网络数据包生成:
- 根据特定的网络协议规范,创建网络数据包对象。这可以包括数据包头和数据包主体。
- 在各种编程语言中,有库和工具可用于构建和编码网络数据包,如
struct
模块(Python)、ByteBuffer
(Java)等。
- XML和JSON生成:
- 对于XML,可以使用XML解析库或API创建XML文档对象,然后添加元素和属性。
- 对于JSON,可以创建JSON对象,包括键值对和嵌套的数组和对象。
- 数据库记录生成:
- 使用数据库连接库或ORM(对象关系映射)工具创建数据库记录对象。不同的编程语言和数据库系统有不同的方法来操作数据库。
- 设置记录的字段值,然后执行插入或更新操作。
- HTML生成:
- 创建HTML文档对象,然后使用HTML标签和属性来构建文档。
- 在许多编程语言中,可以使用字符串拼接或HTML构建库来构建HTML文档。
- 复杂对象生成:
- 根据数据结构的定义,构建复杂的数据对象。这可能涉及创建嵌套的数据结构、图形对象等。
- 使用编程语言的数据结构和面向对象编程的功能来创建对象。
3.多阶段交互类型数据生成方法
当测试对象向外界提供服务的过程包含多次数据交互时,客户端与服务端的数据包必须根据对方的请求与相应进行构造,双方按照协议约定的过程按次序发送数据。多阶段交互类型数据生成方法用于模拟具有多次数据交互的复杂场景,通常在客户端和服务端之间进行数据包的交互。这种方法模拟了真实世界中的数据通信过程,涵盖了多个阶段的数据生成和交互,以测试系统的互操作性和完整性。
简单来说就是通过交互进行数据生成。
以下是多阶段交互类型数据生成方法的一般步骤:
-
定义交互协议:
- 首先,需要明确定义客户端和服务端之间的交互协议。这包括请求和响应的消息格式、顺序、字段和协议规范。
-
生成请求数据:
- 从客户端的角度开始,生成符合协议规范的请求数据包。这可能包括构建请求头、请求体、参数等信息。
-
发送请求:
- 将生成的请求数据发送到服务端,模拟客户端向服务端发出请求。
-
解析请求:
- 在服务端接收到请求后,解析请求数据包,检查其有效性和合法性。服务端需要遵循协议规范来处理请求。
-
生成响应数据:
- 根据接收到的请求,服务端生成符合协议规范的响应数据包。这包括构建响应头、响应体、状态码等信息。
-
发送响应:
- 将生成的响应数据发送回客户端,模拟服务端对客户端的响应。
-
解析响应:
- 客户端接收到响应后,解析响应数据包,验证响应是否符合协议规范。
-
继续交互:
- 根据协议规范,可能需要进行多轮的数据交互。客户端和服务端依次生成请求和响应,模拟多阶段的交互。
-
结束交互:
- 最后,根据测试需求,可以结束交互并生成测试报告,分析交互期间发现的问题和异常。
多阶段交互类型数据生成方法可以帮助测试人员或工具模拟复杂的数据通信场景,以确保系统在实际使用中能够正确处理多个数据交互步骤。这对于测试网络应用程序、通信协议、API等非常重要,因为它可以发现系统中的互操作性问题、数据丢失、顺序错误等潜在问题。
环境控制技术
1.运行环境控制技术
运行环境控制技术在模糊测试中扮演着重要的角色,它涉及到管理和控制模糊测试的执行环境,以确保测试的可控性和可重复性。
简单来说就是构建一个符合测试实际的环,能够控制和维护,并且进行恢复的技术。
构建环境
->控制和维护
->恢复
以下是关于运行环境控制技术的一些常见内容:
-
虚拟化和容器化:
- 使用虚拟机或容器技术可以创建隔离的测试环境,使测试过程不会对实际系统产生影响。
- 通过虚拟化或容器化,可以轻松创建多个独立的测试环境,每个环境可以运行不同的测试用例。
-
快照和还原:
- 创建运行环境的快照,以记录环境的状态和配置。在测试结束后,可以还原环境到快照状态,确保每次测试都从相同的起点开始。
- 这对于确保可重复性和排查问题非常有用。
-
资源隔离:
- 控制测试过程中的资源使用,以避免测试对主机系统的影响。
- 可以限制CPU、内存、网络带宽等资源的使用,确保测试不会导致系统崩溃或不稳定。
-
环境变量控制:
- 通过设置环境变量,可以控制测试过程中使用的配置和参数。这包括路径、文件配置、网络地址等。
- 确保测试环境与实际环境的配置一致。
-
随机性控制:
- 有时模糊测试需要随机生成输入数据,但也可能需要控制随机性,以确保测试可控。
- 可以使用种子值来控制伪随机数生成器的行为,以在多次测试中生成相同的随机数据。
-
日志和监控:
- 记录测试过程中的日志和监控数据,以便后续分析和排查问题。
- 这包括记录测试用例、异常情况、资源利用率等信息。
-
恢复机制:
- 在测试过程中,可能会发生不正常的情况,如崩溃或异常。具备恢复机制可以在测试中自动处理这些问题,使测试能够继续进行。
-
并发和分布式测试:
- 在模糊测试中,可能需要同时执行大量测试用例,使用并发和分布式测试可以提高测试效率。
- 这涉及到控制多个测试实例的协同工作,确保它们不会相互干扰。
运行环境控制技术的目标是确保模糊测试的可控性、可重复性和安全性。通过这些技术,可以更好地管理测试环境,从而更有效地发现潜在的问题和漏洞。
2.程序运行控制技术
- 程序启动和终止:
- 控制模糊测试程序的启动和终止,确保它可以在需要时启动,以及在测试结束后正确终止。
- 暂停和继续:
- 允许在测试过程中暂停 fuzz 测试程序的执行,以便检查状态、调试问题或进行其他操作。之后可以继续执行测试。
- 调试和修改:
- 提供调试功能,允许测试人员在运行时检查程序状态、变量值和执行路径,以排查问题。
- 在需要时,还可以修改程序的行为,例如修改输入数据、修改配置或注入调试语句。
- 进程句柄控制:
- 使用进程句柄,可以监控和控制 fuzz 测试程序的执行。这包括获取进程状态、发送信号、终止进程等。
- API接口:
- 提供各种API接口,以便外部程序与 fuzz 测试程序进行通信和控制。这些接口可以用于启动测试、发送测试用例、检索测试结果等。
3.数据强制输入技术
Fuzz测试的数据强制输入技术是用于将模糊测试生成的测试数据传递给目标程序的方法。这些技术涵盖了多个方面,包括网络数据输入、文件数据输入、用户操作输入以及内存数据修改。
分别用于网络、文件、图形用户界面和内存攻击。
以下是关于这些技术的详细说明:
-
网络数据输入技术:
- 在网络数据输入技术中,模糊测试工具通过模拟网络通信方式将生成的测试数据发送给目标程序。这通常涉及以下步骤:
- 网络形式强制发送:工具使用适当的网络协议连接到目标程序,按照协议规范将测试数据发送给目标。
- 连接协议:模糊测试工具使用与目标程序通信所需的协议,例如HTTP、FTP、SMTP等。
- 数据包构造:根据协议规范构造符合格式的数据包,将测试数据包含在数据包中。
- 这种方法适用于测试网络应用程序、服务器、通信协议等,以验证它们对不规范或恶意输入的鲁棒性。
- 在网络数据输入技术中,模糊测试工具通过模拟网络通信方式将生成的测试数据发送给目标程序。这通常涉及以下步骤:
-
文件数据输入技术:
- 文件数据输入技术用于将生成的测试数据传递给目标程序的方式,通常通过文件传递。这包括以下方法:
- 命令行参数传入:模糊测试工具将测试数据作为命令行参数传递给目标程序。
- 进程交互机制:工具可以通过与目标程序的进程进行交互,将数据传递给正在运行的程序。
- 文件读取:测试工具可以创建临时文件,将测试数据写入文件,然后通过文件读取操作将数据提供给目标程序。
- 这种方法适用于测试本地应用程序、命令行工具等,以验证它们对不同数据源的处理。
- 文件数据输入技术用于将生成的测试数据传递给目标程序的方式,通常通过文件传递。这包括以下方法:
-
用户操作输入技术:
- 用户操作输入技术模拟用户与目标程序进行交互的方式,包括模拟鼠标、键盘输入和其他用户界面操作。这包括以下方法:
- 模拟鼠标和键盘输入:工具模拟用户通过键盘输入文本、通过鼠标点击按钮或执行其他用户界面操作,将测试数据输入到目标程序中。
- 这种方法适用于测试图形用户界面(GUI)应用程序,以验证它们对用户输入的鲁棒性。
- 用户操作输入技术模拟用户与目标程序进行交互的方式,包括模拟鼠标、键盘输入和其他用户界面操作。这包括以下方法:
-
内存数据修改技术:
- 内存数据修改技术允许模糊测试工具直接在目标程序的内存中修改数据,以模拟恶意攻击或异常情况。这包括以下方法:
- 直接在内存中进行修改:工具通过访问目标程序的内存空间,修改特定的内存位置,注入测试数据或更改程序状态。
- 这种方法通常用于测试漏洞、缓冲区溢出等安全问题,以评估程序的鲁棒性。
- 内存数据修改技术允许模糊测试工具直接在目标程序的内存中修改数据,以模拟恶意攻击或异常情况。这包括以下方法:
这些数据强制输入技术允许模糊测试工具将测试数据传递给目标程序,以评估程序的鲁棒性和安全性。根据测试目标和应用程序的性质,可以选择适当的技术来进行模糊测试。
状态监控技术
状态监控技术在模糊测试中起着关键作用,它允许测试人员监控目标程序的生命周期、执行状态、异常状态以及输入输出,从而更好地评估程序的鲁棒性和安全性。以下是关于这些监控技术的简要说明:
-
生命周期监控技术:
- 生命周期监控技术用于追踪目标程序的整个生命周期,包括启动、执行和终止阶段。
- 实现方法:
- 启动和终止:监控程序的启动和终止,可以通过记录程序的启动时间和结束时间来实现。
- 进程监控:使用操作系统提供的工具或库来监控目标程序的进程,以确保它始终处于活动状态。
- 日志记录:记录程序的运行日志,包括启动和终止事件,以便进行后续分析。
-
输入输出监控技术:
- 输入输出监控技术用于捕获目标程序与外部环境的数据交互,包括输入数据和输出结果。
- 实现方法:
- 输入捕获:截获模糊测试工具生成的输入数据,包括网络数据、文件数据、用户操作等。
- 输出监控:捕获目标程序的输出结果,包括响应数据、日志、错误信息等。
- 数据流追踪:使用数据流分析工具来追踪输入数据在程序内部的处理过程,以检测数据修改或异常行为。
-
执行状态监控技术:
- 执行状态监控技术用于实时监控目标程序的执行状态,以检测异常行为和问题。
- 实现方法:
- 异常检测:监控程序的执行过程,检测是否出现异常情况,如崩溃、死锁、超时等。
- 内存检查:定期检查程序的内存使用情况,以检测内存泄漏或溢出问题。
- CPU利用率:监控程序的CPU利用率,以确定是否存在高负载情况。
这些监控技术可以通过使用各种工具和库来实现,具体方法取决于测试环境和测试工具的要求。通过监控目标程序的生命周期、输入输出和执行状态,测试人员可以及时发现异常情况并进行更准确的控制和分析,以提高模糊测试的效率和效果。
0x04 模糊测试优化方法
让我分别解释一下这些方法:
灰盒模糊测试:
灰盒模糊测试是介于白盒(静态分析)和黑盒(仅关注输入输出)之间的一种测试方法。
在灰盒模糊测试中,测试人员或工具通常会逆向工程目标程序,分析其内部结构和逻辑,以更好地理解程序的运行方式。
然后,根据这些了解,有针对性地生成测试用例,限定字段值或者注重测试一些关键路径和敏感函数,以提高发现漏洞的机会。
白盒模糊测试:
白盒模糊测试进一步加强了灰盒测试的概念,引入了符号执行等高级分析技术。
在白盒模糊测试中,测试工具会使用逆向工程技术分析目标程序的源代码、控制流、数据流等内部信息。
这些信息用于构建符号执行模型,以理解程序的执行路径,然后生成测试用例,以测试这些路径。
白盒模糊测试可以更全面地覆盖程序的各种执行路径,从而提高漏洞的发现概率。
基于反馈的模糊测试:
- 基于反馈的模糊测试方法侧重于收集和分析测试过程中产生的反馈信息,以优化后续测试用例的生成。
- 在此方法中,测试工具会统计分析模糊测试用例的特征和测试结果的特征。
- 使用这些信息,测试工具可以动态地调整测试用例生成策略,以生成更有潜力的测试用例,进一步提高发现漏洞的效率。
- 这种方法通常使用统计方法(如u测试)来分析和调整测试用例的生成,从而实现智能的测试。
这些高级模糊测试方法旨在通过更深入的分析和优化来提高模糊测试的效率和效果。它们通常需要更多的专业知识和复杂的工具支持,但可以在发现漏洞方面取得更好的结果。选择哪种方法通常取决于测试目标、测试环境和可用资源。
0x05 工具推荐
这里有几种与模糊测试相关的工具和技术,包括AFL-Unicorn、Qiling、SlowFuzz、PerfFuzz、以及AFL++的QEMU和Unicorn模式。让我们来看看它们的优点、缺点以及双重作用:
-
AFL-Unicorn:
优点:
允许将American Fuzzy Lop(AFL)与Unicorn引擎结合使用,从而能够对更广泛的目标进行模糊测试。
具有高度可定制性,用户可以为目标二进制文件创建自定义的Unicorn插件。
缺点:
复杂性较高,需要熟悉AFL和Unicorn。
需要较多的配置和调试。
-
Qiling:
优点:
可以模拟多种操作系统,包括Linux、Windows等,使其具有广泛的应用。
允许用户在用户模式和内核模式下进行模糊测试。
缺点:
需要深入了解操作系统的内部工作原理,以进行高效的模糊测试。
需要额外的配置和学习曲线。
-
SlowFuzz:
优点:
采用基于符号执行的方法,具有较高的漏洞发现潜力。
能够在更广泛的输入空间中搜索漏洞。
缺点:
符号执行速度较慢,可能需要更多的时间来执行测试。
可能需要更多的计算资源。
-
PerfFuzz:
优点:
利用性能计数器(Performance Counters)来导向模糊测试,从而提高了测试效率。
可以更快地发现性能敏感漏洞。
缺点:
对于一些非性能相关的漏洞,可能不够敏感。
对于某些平台,可能需要额外的硬件支持。
-
AFL++的QEMU和Unicorn模式:
优点:
可以使用AFL++与QEMU或Unicorn引擎结合,提供了广泛的目标支持。
AFL++改进了原始AFL的性能和功能,提供了更好的模糊测试体验。
缺点:
需要一定的配置和学习曲线。
在某些情况下,可能需要更多的计算资源。
这些工具和技术各有优点和缺点,选择哪一个取决于具体需求和目标。例如,如果需要测试多个操作系统,Qiling可能是一个不错的选择。如果关注性能敏感漏洞,PerfFuzz可能更合适。另外,一些工具可以结合使用,以充分发挥各自的优势。最终,选择合适的工具取决于您的具体测试场景和资源可用性。
0x06 尾声
阅读到这里我们简单了解了模糊测试(Fuzz Testing)的各个方面,包括其基本概念、方法和相关技术。模糊测试作为一种强大的测试方法,具有广泛的应用领域,可用于发现软件漏洞、提高安全性和质量。
我们深入了解了模糊测试的基本要素,包括测试用例、异常测试用例和等价测试用例,以及数据集合和程序执行路径。这些概念构成了模糊测试的基础。探索了模糊测试的不同阶段,包括测试数据生成、数据交互与控制、测试结果反馈,以及这些阶段的关联模块和技术。这些阶段共同构建了模糊测试的全貌。
此外,我们介绍了一些高级模糊测试技术,如灰盒模糊测试、白盒模糊测试和基于反馈的模糊测试,以及它们的应用和优势。并且最后,推荐了一些相关工具及其优劣。
接下来,让我们把主动权交回你的手里,去探索更广阔的网络安全世界吧!
相关文章:
Fuzz测试:发现软件隐患和漏洞的秘密武器
0x01 什么是模糊测试 模糊测试(Fuzz Testing)是一种广泛用于软件安全和质量测试的自动化测试方法。它的基本思想是向输入参数或数据中注入随机、不规则或异常的数据,以检测目标程序或系统在处理不合法、不正常或边缘情况下的行为。模糊测试通…...
无为WiFi的一批服务器
我们在多个地区拥有高速服务器,保证网速给力,刷片无压力 嘿嘿 <?phpinclude("./includes/common.php"); $actisset($_GET[act])?daddslashes($_GET[act]):null; $urldaddslashes($_GET[url]); $authcodedaddslashes($_GET[authcode]);he…...
SpringBoot3.0——踩坑
SpringBoot3.0后有一些改动 JDK要17以上lombok <dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.20</version> </dependency>servlet <dependency><groupId>ja…...
Springboot的自动装配原理和文件上传FastDFS
Spring Boot的自动装配原理: Spring Boot的自动装配原理是基于约定大于配置的原则,它通过扫描类路径下的各种文件以及类的注解信息来自动配置应用程序的各种组件和功能。Spring Boot会根据约定的规则自动配置相应的Bean,这些Bean都是单例的&…...
【数据库开发】DQL操作和多表设计
数据库开发 一、数据库操作-DQL 1.概述 用来查询数据库表中的记录,查询操作分为两部分,单表操作和多表操作,针对于查询而言(相较于增删改更加的灵活)基于目标分析条件转换为SQL语句 2.语法 SELECT 字段列表 FROM表…...
用PyTorch轻松实现二分类:逻辑回归入门
💗💗💗欢迎来到我的博客,你将找到有关如何使用技术解决问题的文章,也会找到某个技术的学习路线。无论你是何种职业,我都希望我的博客对你有所帮助。最后不要忘记订阅我的博客以获取最新文章,也欢…...
[nltk_data] Error loading stopwords: <urlopen error [WinError 10054]
报错提示: >>> import nltk >>> nltk.download(stopwords) 按照提示执行后 [nltk_data] Error loading stopwords: <urlopen error [WinError 10054] 找到路径C:\\Users\\EDY\\nltk_data,如果没有nltk_data文件夹,在…...
基于Spring Boot的网上租贸系统设计与实现(源码+lw+部署文档+讲解等)
文章目录 前言具体实现截图论文参考详细视频演示为什么选择我自己的网站自己的小程序(小蔡coding)有保障的售后福利 代码参考源码获取 前言 💗博主介绍:✌全网粉丝10W,CSDN特邀作者、博客专家、CSDN新星计划导师、全栈领域优质创作…...
通过IP地址管理提升企业网络安全防御
在今天的数字时代,企业面临着越来越多的网络安全威胁。这些威胁可能来自各种来源,包括恶意软件、网络攻击和数据泄露。为了提高网络安全防御,企业需要采取一系列措施,其中IP地址管理是一个重要的方面 1. IP地址的基础知识 首先&a…...
termius mac版无需登录注册直接永久使用
1. 下载地址:termius下载 2. 解压安装 3. 当出现 “termius”已损坏,无法打开 则输入以下命令即可:sudo xattr -r -d com.apple.quarantine /Applications/Termius.app 最后去 系统设置-> 隐私与安全性-> 仍要打开 4. 删除app-update.yml文件&…...
TPU编程竞赛|Stable Diffusion大模型巅峰对决,第五届全球校园人工智能算法精英赛正式启动!
目录 赛题介绍 赛题背景 赛题任务 赛程安排 评分机制 奖项设置 近日,2023第五届全球校园人工智能算法精英赛正式开启报名。作为赛题合作方,算丰承办了“算法专项赛”赛道,提供赛题「面向Stable Diffusion的图像提示语优化」,…...
微信小程序 rpx 转 px
前言 略 rpx 转 px let query wx.createSelectorQuery(); query.selectViewport().boundingClientRect(function(res){let rpx2Px 1 * (res.width/750);console.log("1rpx " rpx2Px "px"); }); query.exec();参考 https://blog.csdn.net/qq_39702…...
机器学习之旅-从Python 开始
导读你想知道如何开始机器学习吗?在这篇文章中,我将简要概括一下使用 Python 来开始机器学习的一些步骤。Python 是一门流行的开源程序设计语言,也是在人工智能及其它相关科学领域中最常用的语言之一。机器学习简称 ML,是人工智能…...
100天精通Python(可视化篇)——第103天:Pyecharts绘制多种炫酷水球图参数说明+代码实战
文章目录 专栏导读一、水球图介绍1. 水球图是什么?2. 水球图的应用场景二、水球图类配置选项1. 导包2. Liquid类3. add函数三、水球图实战1. 基础水球图2. 矩形水球图3. 圆棱角矩形水球图4. 三角形水球图5. 菱形水球图6. 箭头型水球图7. 修改数据精度8. 设置无边框9. 多个并排…...
好用的文件备份软件推荐!
为什么需要文件备份软件? 在我们使用计算机的日常工作生活中,可能会遇到各种不同类型的文件,例如文档、Word文档、Excel表格、PPT演示文稿、图片等,这些数据中可能有些对我们来说很重要,但是可能会因为一些意外状况…...
1130 - Host ‘192.168.10.10‘ is not allowed to connect to this MysOL server
mysql 远程登录报错误信息:1130 - Host 124.114.155.70 is not allowed to connect to this MysOL server //需要在mysql 数据库目录下修改 use mysql; //更改用户的登录主机为所有主机,%代表所有主机 update user set host% where userroot; //刷新权…...
如何实现 Es 全文检索、高亮文本略缩处理
如何实现 Es 全文检索、高亮文本略缩处理 前言技术选型JAVA 常用语法说明全文检索开发高亮开发Es Map 转对象使用核心代码 Trans 接口(支持父类属性的复杂映射)Trans 接口的不足真实项目落地效果 前言 最近手上在做 Es 全文检索的需求,类似于…...
Netty(四)NIO-优化与源码
Netty优化与源码 1. 优化 1.1 扩展序列化算法 序列化,反序列化主要用于消息正文的转换。 序列化:将java对象转为要传输对象(byte[]或json,最终都是byte[]) 反序列化:将正文还原成java对象。 //java自带的序列化 // 反序列化 b…...
我的创业之路:我为什么选择 Angular 作为前端的开发框架?
我是一名后端开发人员,在上班时我的主要精力集中在搜索和推荐系统的开发和设计工作上,我比较熟悉的语言包括java、golang和python。对于前端技术中typescript、dom、webpack等流行的框架和工具也懂一些。目前,已成为一名自由职业者࿰…...
阿里云服务器ECS是什么?云服务器详细介绍
阿里云服务器ECS英文全程Elastic Compute Service,云服务器ECS是一种安全可靠、弹性可伸缩的云计算服务,阿里云提供多种云服务器ECS实例规格,如经济型e实例、通用算力型u1、ECS计算型c7、通用型g7、GPU实例等,阿里云服务器网分享阿…...
深入了解快速排序:原理、性能分析与 Java 实现
快速排序(Quick Sort)是一种经典的、高效的排序算法,被广泛应用于计算机科学和软件开发领域。本文将深入探讨快速排序的工作原理、步骤以及其在不同情况下的性能表现。 什么是快速排序? 快速排序是一种基于分治策略的排序算法&am…...
[晕事]今天做了件晕事22;寻找99-sysctl.conf; systemd
这个文件,使用ls命令看不出来是一个链接。 然后满世界的找这个文件怎么来的,后来发现是systemd里的一个文件。 从systemd的源文件里也没找到相关的文件信息。 最后把这个rpm安装包下载下来,才找到这个文件原来是一个链接 #ll /etc/sysctl.d/9…...
2578. 最小和分割
给你一个正整数 num ,请你将它分割成两个非负整数 num1 和 num2 ,满足: num1 和 num2 直接连起来,得到 num 各数位的一个排列。 换句话说,num1 和 num2 中所有数字出现的次数之和等于 num 中所有数字出现的次数。num1…...
Mybatis mapper报错:Class not found: org.jboss.vfs.VFS
报错 Logging initialized using class org.apache.ibatis.logging.stdout.StdOutImpl adapter. Class not found: org.jboss.vfs.VFS JBoss 6 VFS API is not available in this environment. Class not found: org.jboss.vfs.VirtualFile VFS implementation org.apache.iba…...
ARM作业1
三盏灯流水 代码 .text .global _start _start: 1.设置GPIOE寄存器的时钟使能 RCC_MP_AHB4ENSETR[4]->1 0x50000a28 LDR R0,0X50000A28 LDR R1,[R0] 从r0为起始地址的4字节数据取出放在R1 ORR R1,R1,#(0x3<<4) 第4位设置为1 STR R1,[R0] 写回2.设置PE10管…...
leetcode 502. IPO
假设 力扣(LeetCode)即将开始 IPO 。为了以更高的价格将股票卖给风险投资公司,力扣 希望在 IPO 之前开展一些项目以增加其资本。 由于资源有限,它只能在 IPO 之前完成最多 k 个不同的项目。帮助 力扣 设计完成最多 k 个不同项目后…...
[软考中级]软件设计师-计算机网络
网络设备 物理层 物理层不能隔离广播域和冲突域 中继器,集线器 集线器可看成是特殊的多路中继器 数据链路层 可以隔离冲突域不能隔离广播域 网桥,交换机 交换机是多端口的网桥 网络层 可以隔离广播域和冲突域 路由器 应用层 网关 协议簇 …...
Linux搭建我的世界MC服务器 【Minecraft外网联机教程】
目录 前言 1. 安装JAVA 2. MCSManager安装 3.局域网访问MCSM 4.创建我的世界服务器 5.局域网联机测试 6.安装cpolar内网穿透 7. 配置公网访问地址 8.远程联机测试 9. 配置固定远程联机端口地址 9.1 保留一个固定tcp地址 9.2 配置固定公网TCP地址 9.3 使用固定公网…...
APISIX 中ETCD 的问题
1. 问题1 : Error: client: etcd cluster is unavailable or misconfigured; error #0: client: endpoint http://etcd:2379 exceeded header timeout error #0: client: endpoint http://etcd:2379 exceeded header timeout 修改APISIX config ETCD_ADVERTISE_CL…...
SSH版本信息可被获取
漏洞描述 Name SSH版本信息可被获取 Description SSH服务允许远程攻击者获得ssh的具体信息,如版本号等等。这可能为攻击者发动进一步攻击提供帮助。 CVE No. CVE-1999-0634 分析结果 该问题不属于漏洞,不存在安全风险。SSH协议是一种安全协议&am…...
新网站不被收录/电商网站大全
文章目录React 简介React 概述及特点React 虚拟DOMReact 渲染机制React 基本使用JSX 语法createElement()方法深究JSX语法规则React 简介 React 概述及特点 是一个用于构建用户界面,将数据渲染为HTML视图的开源 JavaScript库 中文官网:React官方中文文档…...
长沙网站建设王道下拉惠/百度分析
JavaScript深入理解——变量对象(Variable object) 概要 我们总是会在程序中定义一些函数和变量,之后会使用这些函数和变量来构建我们的系统。 然而,对于解释器来说,它又是如何以及从哪里找到这些数据的(函数,变量)?当…...
公司部门团建活动策划方案/深圳百度推广排名优化
数据结构有八大类 1、数组2、栈3、队列4、链表5、树6、散列表7、堆8、图链表基本操作:头位置添加、头位置删除、任意位置添加、任意位置删除、根据下标查找节点、根据数据查找节点、获取长度、打印所有节点 package com.autumn.LinkedList;/*** 节点*/ class Node{p…...
web网站做二级标题是什么意思/网络营销咨询服务
http://os.51cto.com/art/201304/388084.htm转载于:https://blog.51cto.com/youkanzhao/1174851...
Hdi做指数网站/网络整合营销4i原则是指
今天我们来画折线图 效果图以下为模拟数据[{"time":19,"text":"入\n院\n19\n时\n11\n分","position":42,"cellMin":29.0,"cellSplit":0.2,"type":"text","color":"red",…...
企业b2b电子商务平台/淘宝seo是什么
在过去单核CPU时代,单任务在一个时间点只能执行单一程序。之后发展到多任务阶段,计算机能在同一时间点并行执行多任务或多进程。虽然并不是真正意义上的“同一时间点”,而是多个任务或进程共享一个CPU,并交由操作系统来完成多任务…...