AFL-fuzz没有发现任何崩溃问题
创始人
2024-07-29 17:01:06
0
  1. 确保目标程序可以被 AFL-fuzz 探测到。一般来说,AFL-fuzz 只能探测到一些特定类型的程序,例如 ELF 程序或者缺陷程序。如果你想在工具上运行其他类型的程序,需要使用 QEMU 进行模拟。例如,如下命令可以使用 QEMU 运行 Mac 上的应用程序:
$ afl-fuzz -i input_dir -o output_dir -- /usr/local/bin/qemu-system-x86_64 -vga none -nographic -fda test.img -m 100M -hda /dev/sda -hdb /dev/sdb -net none -kernel-kqemu -append "root=/dev/sda1 console=ttyS0"
  1. 确认目标程序中存在可以导致崩溃的漏洞。通常情况下,AFL-fuzz 需要某些特定的执行路径才能发现崩溃漏洞。因此,如果没有发现任何崩溃,可以重新审查你的代码,确认是否存在可以导致异常情况的程序路径。例如,在以下代码中,当输入大于 32 时,会导致程序崩溃:
#include 
#include 

void foo(char *data) {
    char buffer[32];
    strncpy(buffer, data, sizeof(buffer) - 1);
    buffer[sizeof(buffer) - 1] = '\0';
    printf("%s\n", buffer);
}

int main(int argc, char **argv) {
    char *data = argv[1];
    foo(data);
    return 0;
}
  1. 确认你的测试集是否充分,是否包含足够多的正确和恶意数据。通常情况下,测试集应该充分覆盖可能的输入路径,并尽可能完整地

相关内容

热门资讯

Android Recycle... 要在Android RecyclerView中实现滑动卡片效果,可以按照以下步骤进行操作:首先,在项...
安装apache-beam==... 出现此错误可能是因为用户的Python版本太低,而apache-beam==2.34.0需要更高的P...
Android - 无法确定任... 这个错误通常发生在Android项目中,表示编译Debug版本的Java代码时出现了依赖关系问题。下...
Android - NDK 预... 在Android NDK的构建过程中,LOCAL_SRC_FILES只能包含一个项目。如果需要在ND...
Akka生成Actor问题 在Akka框架中,可以使用ActorSystem对象生成Actor。但是,当我们在Actor类中尝试...
Agora-RTC-React... 出现这个错误原因是因为在 React 组件中使用,import AgoraRTC from “ago...
Alertmanager在pr... 首先,在Prometheus配置文件中,确保Alertmanager URL已正确配置。例如:ale...
Aksnginxdomainb... 在AKS集群中,可以使用Nginx代理服务器实现根据域名进行路由。以下是具体步骤:部署Nginx i...
AddSingleton在.N... 在C#中创建Singleton对象通常是通过私有构造函数和静态属性来实现,例如:public cla...
Alertmanager中的基... Alertmanager中可以使用repeat_interval选项指定在一个告警重复发送前必须等待...