首页> 中文学位 >基于动态符号执行的模糊测试方法研究
【6h】

基于动态符号执行的模糊测试方法研究

代理获取

目录

声明

摘要

第1章 绪论

1.1 研究背景及意义

1.2 国内外研究现状

1.2.1 模糊测试研究现状

1.2.2 符号执行研究现状

1.2.3 基于动态符号执行的模糊测试研究现状

1.3 主要研究内容

1.4 论文组织与结构

1.5 本章小结

第2章 相关理论与方法

2.1 模糊测试

2.1.1 模糊测试概述

2.1.2 基本流程

2.1.3 测试用例生成方法

2.2 动态符号执行

2.2.1 符号执行概述

2.2.2 动态符号执行的过程

2.2.3 动态符号执行面对的问题

2.2.4 动态符号执行工具

2.3 本章小结

第3章 基于动态符号执行的模糊测试方法框架

3.1 总体设计

3.1.1 工作流程

3.1.2 总体架构

3.2 插桩模块

3.2.1 源代码插桩与二进制插桩

3.2.2 静态插桩与动态插桩

3.2.3 动态二进制插桩工具Pin

3.2.4 插桩模块的实现

3.3 路径约束生成模块

3.3.1 路径约束生成模块流程

3.3.2 广度优先策略(Breadth-First Search,BFS)

3.3.3 深度优先策略(Depth-First Search,DFS)

3.3.4 基于代的路径遍历策略(Generation Search,GS)

3.4 求解器模块

3.4.1 求解器模块流程

3.4.2 常见的求解器

3.4.3 求解器面临的问题

3.5 本章小结

第4章 基于动态符号执行的模糊测试方法优化

4.1 基于代的启发式路径遍历策略

4.1.1 启发式路径遍历策略

4.1.2 基于代的启发式路径遍历策略具体实现

4.2 Z3与STP综合求解器

4.2.1 Z3与STP

4.2.2 SMT-LIB2.0 标准语言

4.2.3 中间层

4.2.4 综合求解器具体实现

4.3 本章小结

第5章 实验与分析

5.1 实验环境

5.2 实验内容

5.2.1 实验指标

5.2.2 实验案例

5.2.3 实验结果分析

5.3 本章小结

第6章 总结与展望

6.1 论文主要工作总结

6.2 下一步工作展望

参考文献

攻读学位期间公开发表论文

致谢

展开▼

摘要

随着互联网的发展,软件已经渗透到人们生活的方方面面。由于软件功能的多样化,代码量和复杂度也逐渐变高。随之而来的安全问题引起广泛关注,软件安全问题影响着使用者的信息安全,一旦信息遭到泄露会造成无法挽回的后果。所以提高软件安全性是很有必要的。漏洞检测是改善软件安全性的一种行之有效的方法,因此对漏洞检测技术的研究是很有意义的。本文对基于动态符号执行的模糊测试方法进行研究,主要内容如下:
  首先,研究基础知识。通过阅读大量文献,将国内外动态符号执行与模糊测试相关研究成果进行对比与总结,抽象出动态符号执行的整体流程。同时研究模糊测试的过程与方法,为下一步研究工作奠定基础。
  其次,构造测试框架。将动态符号执行方法应用到模糊测试中,给出基于动态符号执行的模糊测试方法的框架,通过将初始用例输入到框架中,经过插桩模块、路径约束生成模块和求解器模块,有效的触发漏洞来降低测试用例生成的随机性,提升测试的效率。
  再次,对框架进行路径遍历和求解器两方面的优化。 一是针对动态符号执行流程中路径遍历策略和测试轮次多的问题,研究基于代的启发式路径遍历策略。通过在基于代的路径遍历策略基础上添加评分函数,将程序经过的路径进行打分操作,将根据分数从小到大排序后的路径作为依次下一次测试的输入,从而提高触发漏洞的效率。二是针对动态符号执行流程中的求解器模块存在的支持约束少的问题,研究综合求解器方法。该方法在求解器模块中添加中间层,完成支持多种约束求解的功能。
  最后,对求解器模块和路径约束生成模块分别进行实验,从执行时间和测试轮数两个方面进行验证。通过对漏洞库中漏洞的检测,将基于动态符号执行的模糊测试方法与其它方法进行比较,实验结果表明本方法在一定程度上降低漏报率和误报率,从而证明方法的可行性。

著录项

相似文献

  • 中文文献
  • 外文文献
  • 专利
代理获取

客服邮箱:kefu@zhangqiaokeyan.com

京公网安备:11010802029741号 ICP备案号:京ICP备15016152号-6 六维联合信息科技 (北京) 有限公司©版权所有
  • 客服微信

  • 服务号