热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【论文分享】SequenceDirectedHybridFuzzing

这篇文章发表于CCFB类会议SANER2020,是ICPC19年一篇工作的改进版Sequencecoveragedirectedgreyboxfuzzing主要的变

这篇文章发表于CCF B类会议SANER 2020,是ICPC 19年一篇工作的改进版Sequence coverage directed greybox fuzzing

主要的变化是原来是单纯的fuzz,现在是hybird Fuzz,也就是加入了符号执行来作为辅助。

这篇工作要解决的问题是:现有的定向模糊测试没有在effectness和efficiency上达到很好的平衡,也很难基于随机变异来覆盖复杂的路径。

方法

文章主要是在能量调度算法和种子选择策略做了修改。能量调度算法是根据目标序列和种子执行轨迹的相似度进行比较。种子选择策略在lolly基础上,又多考虑了到达目标的路径上的必要点。变异输入部分再结合concolic execution来高效生成覆盖复杂条件的输入。

文章的总体框架如下所示,分为静态分析和动态分析两个部分。

静态分析首先把目标序列和源码的行号转化为基本块,并且基于dominant tree analysis求出ETS。其中ETS表示的是enhanced target sequence,意思是目标序列和到达目标序列的必要节点的结合。然后插桩主要是为了在运行时获得分支覆盖率和目标执行轨迹的信息。

动态分析部分,fuzzer的输入是插桩后的二进制和ETS,然后fuzz的过程时,把种子放在三种级别的队列中,分别是L1,L2,L3,表示高优先级,普通优先级,低优先级。Concolic Executor的输入是测试的二进制(PUT)和L1级别的种子,并且把新生成的种子放在L2级别。

image-20220216172449097

Static Analysis

为了支持细粒度的调度种子,文章考虑了目标序列的覆盖率以及他们的执行上下文(也就是到达目标序列的必要节点)。执行上下文获取的算法如下图所示:

image-20220217105107067

在控制流图中,如果到达节点n的每条路径都需要经过节点d,那么就叫节点d为节点n的支配节点。如果树上的每个节点只支配自身及其子节点,就叫这个树为支配树。

上面的算法里,n0是entry node,N是所有基本块的集合。对于一个基本块n,他的支配节点是节点n所有前驱节点的支配节点的交集。所以,一开始的时候,对于任意一个节点n,先将他的支配节点的集合设为N。然后再迭代式地移除不属于节点n的支配节点(5-9行)。最后13行-15行是去获取属于目标序列(Target Sequence)的必要节点。

接下来是插桩部分,除了插桩获取覆盖率信息外,SDHF也对ETS的基本块进行插桩,来获取目标执行轨迹TET。覆盖率信息和TET和ETS的相似度将被用于确定种子的优先级。

比如下面的例子,种子的执行轨迹是“aegabdfg”,由静态分析得到的ETS是abcg,通过插桩得到的TET是ababg。

image-20220217110654254

dynamic analysis

动态分析部分主要是fuzzer和concolic executor的交互。

1)fuzzing process

fuzz的总的流程如下所示。首先从种子队列S中取出一个种子s,并且给种子赋予能量p。种子的能量决定了变异这个种子的时间。然后,fuzzer对种子进行变异,并且生成新的种子s‘,如果s’产生了crash,就会把这个种子放在Sx集合中。对于每个新生成的种子s‘,都会去计算种子执行轨迹与ETS的相似度sim以及是否有增加覆盖率cov。如果相似度大于某个阈值d并且有新增覆盖率,则把种子加入L1优先级队列,如果相似度大于d,但没有新增覆盖率,则要放到L2中。如果种子相似度没有大于阈值也没有新增覆盖率,就放到L3。持续这个过程直到超时或者手动中止。

image-20220217114303629

2)concolic execution

concolic execution是fuzzing过程的一个辅助手段,它以部分匹配的种子作为输入,来生成更高相似度的种子。因为fuzzer是依靠随机变异来生成种子,即使fuzzer生成了高相似度的种子,也不能确定新生成的种子接近了目标序列。concolic execution能够获取种子执行的路径并且生成执行特定路径的输入。

这部分的算法如下图所示。首先执行给定的种子S,获得种子S执行的路径Trace。然后遍历路径Trace上的基本块,根据最大匹配前置路径,找到转换点SP的基本块,获取转换点基本块另一个没执行过的子节点的约束,生成新的种子。

image-20220217185724959

实验

在LAVA-M上与QSYM比较发现漏洞效率,TTE表示发现漏洞的时间。

image-20220217191920235

和BugRedux,AFLGo比较复现漏洞的有效性。

image-20220217192202079

与Lolly比True Positives Verifification的能力

image-20220217192408062

最后再用工具挖到了几个真实的漏洞:

image-20220217192519751


推荐阅读
  • 生成式对抗网络模型综述摘要生成式对抗网络模型(GAN)是基于深度学习的一种强大的生成模型,可以应用于计算机视觉、自然语言处理、半监督学习等重要领域。生成式对抗网络 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • 本文介绍了绕过WAF的XSS检测机制的方法,包括确定payload结构、测试和混淆。同时提出了一种构建XSS payload的方法,该payload与安全机制使用的正则表达式不匹配。通过清理用户输入、转义输出、使用文档对象模型(DOM)接收器和源、实施适当的跨域资源共享(CORS)策略和其他安全策略,可以有效阻止XSS漏洞。但是,WAF或自定义过滤器仍然被广泛使用来增加安全性。本文的方法可以绕过这种安全机制,构建与正则表达式不匹配的XSS payload。 ... [详细]
  • 合并列值-合并为一列问题需求:createtabletab(Aint,Bint,Cint)inserttabselect1,2,3unionallsel ... [详细]
  • JavaScript和HTML之间的交互是经由过程事宜完成的。事宜:文档或浏览器窗口中发作的一些特定的交互霎时。能够运用侦听器(或处置惩罚递次来预订事宜),以便事宜发作时实行相应的 ... [详细]
  • ShiftLeft:将静态防护与运行时防护结合的持续性安全防护解决方案
    ShiftLeft公司是一家致力于将应用的静态防护和运行时防护与应用开发自动化工作流相结合以提升软件开发生命周期中的安全性的公司。传统的安全防护方式存在误报率高、人工成本高、耗时长等问题,而ShiftLeft提供的持续性安全防护解决方案能够解决这些问题。通过将下一代静态代码分析与应用开发自动化工作流中涉及的安全工具相结合,ShiftLeft帮助企业实现DevSecOps的安全部分,提供高效、准确的安全能力。 ... [详细]
  • 目录浏览漏洞与目录遍历漏洞的危害及修复方法
    本文讨论了目录浏览漏洞与目录遍历漏洞的危害,包括网站结构暴露、隐秘文件访问等。同时介绍了检测方法,如使用漏洞扫描器和搜索关键词。最后提供了针对常见中间件的修复方式,包括关闭目录浏览功能。对于保护网站安全具有一定的参考价值。 ... [详细]
  • 本文总结了在编写JS代码时,不同浏览器间的兼容性差异,并提供了相应的解决方法。其中包括阻止默认事件的代码示例和猎取兄弟节点的函数。这些方法可以帮助开发者在不同浏览器上实现一致的功能。 ... [详细]
  • 颜色迁移(reinhard VS welsh)
    不要谈什么天分,运气,你需要的是一个截稿日,以及一个不交稿就能打爆你狗头的人,然后你就会被自己的才华吓到。------ ... [详细]
  • 初探PLC 的ST 语言转换成C++ 的方法
    自动控制软件绕不开ST(StructureText)语言。它是IEC61131-3标准中唯一的一个高级语言。目前,大多数PLC产品支持ST ... [详细]
  • 点击上方“新机器视觉”,选择加”星标”或“置顶”重磅干货,第一时间送达很早就想总结一下前段时间学习HALCON的心得,但由于其他的事情总是抽不出时间。去年有过一段时间的集中学习,做 ... [详细]
  • 篇首语:本文由编程笔记#小编为大家整理,主要介绍了VoLTE端到端业务详解|VoLTE用户注册流程相关的知识,希望对你有一定的参考价值。书籍来源:艾怀丽 ... [详细]
  • 这篇论文跟普通的论文是区别的,它并不是针对现有问题,提出一个新颖的解决方案,然后对其进行测试评估。这篇论文主要是对文件系统的代码发展做了一 ... [详细]
  • 文章框架前言呀!!再也不三心二意了,从今往后专心搞iOS!嗯!从大一开始就嚷嚷对iOS热爱的很,结果呢,就毕设写了个垃圾,咦!所以现在起,iOS就是我的主线了!先写这篇垃圾文章壮壮 ... [详细]
author-avatar
小白学习哈
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有