基于静态源码分析的软件安全测试技术研究与实现
| 摘要 | 第1-5页 |
| ABSTRACT | 第5-10页 |
| 第一章 引言 | 第10-15页 |
| ·研究背景及意义 | 第10-11页 |
| ·国内外研究现状 | 第11-13页 |
| ·本文主要研究内容 | 第13-14页 |
| ·论文组织结构 | 第14-15页 |
| 第二章 软件安全静态分析技术 | 第15-27页 |
| ·软件测试技术 | 第15-18页 |
| ·软件测试方法分类 | 第15-16页 |
| ·常用软件测试工具 | 第16-17页 |
| ·传统软件测试技术的不足 | 第17-18页 |
| ·软件安全漏洞及检测方法 | 第18-22页 |
| ·使用未初始化变量 | 第19-20页 |
| ·数组越界 | 第20-21页 |
| ·空指针解引用 | 第21页 |
| ·软件安全漏洞检测方法 | 第21-22页 |
| ·静态分析测试技术 | 第22-26页 |
| ·静态分析能解决的问题 | 第23-24页 |
| ·静态分析测试原理 | 第24-25页 |
| ·现有静态分析的局限性 | 第25-26页 |
| ·本章小结 | 第26-27页 |
| 第三章 CT_Check 分析与设计 | 第27-40页 |
| ·系统概述 | 第27-29页 |
| ·CT_Check 系统框架 | 第29-30页 |
| ·CT_Check 各模块功能 | 第30-39页 |
| ·文件解析模块 | 第31-33页 |
| ·主要接口和数据结构 | 第31-32页 |
| ·抽象语法树 | 第32-33页 |
| ·局部分析模块 | 第33-36页 |
| ·主要接口和数据结构 | 第33-35页 |
| ·控制流图 | 第35-36页 |
| ·全局分析模块 | 第36-39页 |
| ·主要接口和数据结构 | 第36-38页 |
| ·函数调用图 | 第38-39页 |
| ·本章小结 | 第39-40页 |
| 第四章 CT_Check 检测算法 | 第40-59页 |
| ·算法概述 | 第40-41页 |
| ·局部分析 | 第41-48页 |
| ·构造控制流图 | 第42-44页 |
| ·使用未初始化变量 | 第44-47页 |
| ·数组越界 | 第47-48页 |
| ·全局分析 | 第48-50页 |
| ·构造函数调用图 | 第49页 |
| ·函数调用图举例 | 第49-50页 |
| ·自定义属性规则 | 第50-57页 |
| ·断言的副作用 | 第52-53页 |
| ·连续赋值错误 | 第53-54页 |
| ·锁规则和中断屏蔽 | 第54-56页 |
| ·空指针解引用 | 第56-57页 |
| ·本章小结 | 第57-59页 |
| 第五章 实验与测试 | 第59-67页 |
| ·测试环境 | 第59页 |
| ·测试命令 | 第59-60页 |
| ·测试结果 | 第60-66页 |
| ·使用未初始化变量 | 第60-61页 |
| ·数组越界 | 第61页 |
| ·空指针解引用 | 第61-63页 |
| ·连续赋值错误 | 第63-64页 |
| ·综合测试 | 第64-66页 |
| ·本章小结 | 第66-67页 |
| 第六章 结论 | 第67-69页 |
| ·工作总结 | 第67-68页 |
| ·今后的研究方向 | 第68-69页 |
| 致谢 | 第69-70页 |
| 参考文献 | 第70-74页 |
| 附录A 控制流图生成算法 | 第74-76页 |
| 附录B 函数调用图生成算法 | 第76-81页 |
| 攻硕期间取得的研究成果 | 第81-82页 |