探索未知的边界:FitM - 中间模糊器
2024-05-23 09:33:41作者:吴年前Myrtle
在软件安全领域,模糊测试(Fuzzing)是一种广泛使用的漏洞发现方法,而FitM正是这一领域的杰出代表。它是一个基于AFL++的覆盖率引导的模糊测试工具,专为无源码状态型的二进制客户端-服务器应用设计。通过FitM,即使在没有源代码的情况下,也能对通信协议进行深入探索。
项目简介
FitM采用独特的"Fuzzer-in-the-Middle"策略,结合了qemuafl的模拟技术和CRIU的用户空间快照功能。无需源代码,即可实现对服务器和客户端的同时模糊测试,揭示它们之间复杂交互中的潜在问题。
技术剖析
FitM的工作原理基于其核心组件FitM-qemu,这是一个扩展版的qemuafl,集成了网络层的系统调用级模拟。它将客户端和服务器置于同一模糊测试环境中,通过循环创建并恢复不同阶段的进程快照来探索协议的不同层次。每次迭代都会从上一阶段的输出作为输入种子,对另一个目标进行模糊测试,从而逐步挖掘协议深度。
应用场景
FitM适用于各种需要深入探索网络协议的场景,如Web服务、数据库接口、加密通信协议等。它可以帮助开发者发现那些常规语法模糊测试工具难以触及的深层次问题,甚至可以在缺少源码的情况下,对二进制库或固件进行安全审计。
项目特点
- 无需源码:FitM的独特之处在于它能处理二进制文件,不需要原始代码,这使得它可以用于任何公开或私有的二进制应用。
- 覆盖全面:通过同时模糊测试客户端和服务器,FitM可以涵盖整个通信流程,找到其他方法可能遗漏的问题。
- 高效智能:利用AFL++的覆盖率指导策略,FitM能够以高效率定向发现潜在的安全隐患。
- 灵活性强:FitM支持自定义配置,你可以调整运行时间,选择要测试的目标,并控制环境变量,以适应不同的测试需求。
开始你的旅程
FitM提供了一套详细的安装指南,只需几步简单的命令,你就可以开始你的模糊测试之旅。对于想要深入了解FitM工作原理的研究者,项目还提供了论文,详细解释了其技术细节和基准测试结果。
无论是安全研究员,还是软件开发者,FitM都是一款值得尝试的强大工具。立即加入FitM的行列,解锁二进制应用中隐藏的未知世界。让我们一起推动软件安全的边界,让互联网更加安全。
登录后查看全文
热门项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0282
GLM-5.2智谱开源 GLM-5.2,这是针对长文本任务的最新旗舰模型。相较于前代产品 GLM-5.1,它在长文本任务处理能力上实现了显著飞跃,并且首次在稳定的 100 万 token 上下文中提供这一能力。Jinja00
JoyAI-VL-Interaction-Preview京东开源首个开源、视觉驱动的实时交互模型——它能实时监控视频流,并自主决定何时发言、保持沉默或委托任务。Jinja00
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0189
MaxKB强大易用的开源企业级智能体平台Python02
note-gen一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。TSX011
项目优选
收起
暂无描述
Dockerfile
789
5.18 K
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
902
2.1 K
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
727
1.45 K
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
473
484
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.14 K
1.18 K
deepin linux kernel
C
32
16
Ascend Extension for PyTorch
Python
769
997
JiuwenSwarm 是一款基于openJiuwen开发的智能AI Agent,它能够将大语言模型的强大能力,通过你日常使用的各类通讯应用,直接延伸至你的指尖。
Python
2.53 K
693
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed.
Get Started
Rust
2.56 K
282
CANNBot 是面向 CANN 开发的用于提升开发效率的系列智能体,本仓库为其提供可复用的 Skills 模块。
Python
1.09 K
687