0

0

c++如何用AFL++进行模糊测试 c++ Fuzzing入门【安全】

尼克

尼克

发布时间:2026-01-01 19:00:50

|

767人浏览过

|

来源于php中文网

原创

用AFL++对C++项目模糊测试的核心是编译时启用插桩(如afl-clang-fast++)、入口函数从stdin/文件读取字节数组输入、捕获异常避免abort,并注意STL、线程等特性干扰。

c++如何用afl++进行模糊测试 c++ fuzzing入门【安全】

用 AFL++ 对 C++ 项目做模糊测试,核心是让目标程序接受一个字节数组输入(通常通过 stdin 或文件),并编译时启用插桩(instrumentation)。C++ 本身没有阻碍,但要注意编译器兼容性、异常处理、标准库行为等细节。

1. 编译时启用 AFL++ 插桩

AFL++ 需要重新编译目标代码,使用其提供的包装器(如 afl++-clang++)替代原编译器。它会自动注入覆盖率反馈逻辑。

  • 确保源码入口是清晰的 int main(int argc, char** argv),且能从 stdin / 文件读取输入(推荐 stdin,更易与 AFL++ 集成)
  • 禁用优化(-O0)和启用调试信息(-g)有助于调试崩溃;生产级 fuzz 可用 -O3,但需确认插桩仍生效
  • 关闭 ASLR 和其他干扰机制:运行前执行 echo core | sudo tee /proc/sys/kernel/core_patternsudo sysctl -w kernel.randomize_va_space=0(仅限测试环境)

2. 编写可 fuzz 的 C++ 入口函数

AFL++ 不直接理解 C++ 类或模板,它只监控底层指令执行路径。你需要把待测逻辑“暴露”为一个可重复调用、无副作用、快速退出的函数,并由 main 驱动。

  • 避免全局构造器中做复杂初始化(可能在 fuzz 过程中多次触发);改用懒加载或每次 fuzz 迭代内显式初始化
  • 捕获 C++ 异常:AFL++ 默认不处理未捕获异常导致的 abort,建议在 main 中用 try { ... } catch (...) { return 0; } 防止崩溃被误判为 crash
  • 示例结构:
extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
  // 将 data 解析为你的输入格式(如字符串、二进制协议)
  std::string input(reinterpret_cast(data), size);
  try {
    parse_my_format(input);  // 你的真实逻辑
  } catch (...) {
    return 0;
  }
  return 0;
}

注意:若使用 libFuzzer 风格接口(LLVMFuzzerTestOneInput),需链接 -fsanitize=fuzzer,而非 AFL++ 插桩——这是两种不同模式。AFL++ 更常用的是传统 main + stdin 模式。

Kacha
Kacha

KaCha是一款革命性的AI写真工具,用AI技术将照片变成杰作!

下载

立即学习C++免费学习笔记(深入)”;

3. 构建与运行 AFL++

推荐使用 AFL++ 的 afl-clang-fast++(基于 LLVM 的高性能插桩)或 afl-g++(基于 GCC 的经典插桩)。

  • 安装 AFL++ 后,设置环境:export AFL_PATH=/path/to/aflpp,并确保 $AFL_PATH 在 PATH 中
  • 编译命令示例:afl-clang-fast++ -O3 -g -o my_target my_target.cpp
  • 准备输入语料库(至少一个合法/半合法输入文件,放在 in/ 目录),然后启动 fuzz:afl-fuzz -i in/ -o out/ -- ./my_target
  • 若程序从文件读输入,用 @@ 占位符:afl-fuzz -i in/ -o out/ -- ./my_target @@

4. 处理 C++ 特有陷阱

std::string、std::vector、异常、RTTI、线程等可能干扰 fuzz 稳定性。

  • 避免在 fuzz 循环中调用 std::exit()abort();改用 return 让 main 正常结束
  • 禁用 STL 的 debug 模式(如 _GLIBCXX_DEBUG)和 sanitizer 冲突(AFL++ 插桩与 AddressSanitizer 可共存,但需用 afl-clang-fast++ -fsanitize=address 统一编译)
  • 多线程程序慎用 AFL++:默认只 fuzz 主线程;如必须支持,请启用 -D__AFL_HAVE_MANUAL_CONTROL 并手动调用 __AFL_INIT(),再用 __AFL_LOOP() 包裹 fuzz 循环

相关文章

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

312

2023.08.02

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

312

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

522

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

49

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

190

2025.08.29

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

989

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

50

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

228

2025.12.29

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

65

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
CSS3 教程
CSS3 教程

共18课时 | 4.2万人学习

Sass 教程
Sass 教程

共14课时 | 0.7万人学习

Pandas 教程
Pandas 教程

共15课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号