软件安全:从源头开始 / 计算机科学丛书
¥59.00定价
作者: [美]詹姆斯·兰萨姆,安莫尔·米斯拉著
译者:丁丽萍、卢国庆等 译;
出版时间:2016-07
出版社:机械工业出版社
- 机械工业出版社
- 9787111540236
- 1版
- 191732
- 44177085-6
- 压膜
- 16开
- 2016-07
- 380
- 205
- 工学
- 软件工程
- TP311.52
- 计算机
- 本科 研究生(硕士、EMBA、MBA、MPA、博士)
内容简介
由詹姆斯·兰萨姆、安莫尔·米斯拉著的《软件安全(从源头开始)》阐述什么是人类可控制管理的安全软件开发过程,给出一种基于经验的方法,来构建好用的安全软件开发模型,以应对安全问题,并在安全软件开发模型中解决安全问题。本书分为三部分,共10章。第1章简要介绍软件安全领域的主题及其重要性;第2章讲解软件安全的难点以及SDL框架。第3~8章揭示如何将SDL及其实践映射到一个通用的SDLC框架。第9章从资深软件安全架构师的角度给出关于成功方案的看法,并且解读在开发安全软件时针对典型挑战的一些真实方法。第10章结合现实世界中的安全威胁,描述如何用合理的架构设计、实现与管理的SDL程序来提高安全性。
目录
出版者的话
序
前言
作者简介
第1章 引论
1.1 软件安全的重要性和相关性
1.2 软件安全和软件开发生命周期
1.3 代码的质量与安全
1.4 SDL三个最重要的安全目标
1.5 威胁建模和攻击面验证
1.6 本章小结:期望从本书中学到什么
参考文献
第2章 安全开发生命周期
2.1 克服软件安全中的挑战
2.2 软件安全成熟度模型
2.3 ISO/IEC 27034:信息技术、安全技术、应用安全
2.4 其他SDL最佳实践的资源
2.4.1 SAFECode
2.4.2 美国国土安全软件保障计划
2.4.3 美国国家标准与技术研究院
2.4.4 MITRE公司公共计算机漏洞和暴露
2.4.5 SANS研究所高级网络安全风险
2.4.6 美国国防部网络安全与信息系统信息分析中心
2.4.7 CERT、Bugtraq和SecurityFocus
2.5 关键工具和人才
2.5.1 工具
2.5.2 人才
2.6 最小特权原则
2.7 隐私
2.8 度量标准的重要性
2.9 把SDL映射到软件开发生命周期
2.10 软件开发方法
2.10.1 瀑布开发
2.10.2 敏捷开发
2.11 本章小结
参考文献
第3章 安全评估(A1):SDL活动与最佳实践
3.1 软件安全团队提早参与项目
3.2 软件安全团队主持发现会议
3.3 软件安全团队创建SDL项目计划
3.4 隐私影响评估计划启动
3.5 安全评估(A1)成功的关键因素和度量标准
3.5.1 成功的关键因素
3.5.2 可交付成果
3.5.3 度量标准
3.6 本章小结
参考文献
第4章 架构(A2):SDL活动与最佳实践
4.1 A2策略一致性分析
4.2 SDL策略评估和范围界定
4.3 威胁建模/架构安全性分析
4.3.1 威胁建模
4.3.2 数据流图
4.3.3 架构威胁分析和威胁评级
4.3.4 风险缓解
4.4 开源选择
4.5 隐私信息收集和分析
4.6 成功的关键因素和度量标准
4.6.1 成功的关键因素
4.6.2 可交付成果
4.6.3 度量标准
4.7 本章小结
参考文献
第5章 设计和开发(A3):SDL活动与最佳实践
5.1 A3策略一致性分析
5.2 安全测试计划构成
5.3 威胁模型更新
5.4 设计安全性分析和检查
5.5 隐私实现评估
5.6 成功的关键因素和度量标准
5.6.1 成功的关键因素
5.6.2 可交付成果
5.6.3 度量标准
5.7 本章小结
参考文献
第6章 设计和开发(A4):SDL活动与最佳实践
6.1 A4策略一致性分析
6.2 安全测试用例执行
6.3 SDLC/SDL过程中的代码审查
6.4 安全分析工具
6.4.1 静态分析
6.4.2 动态分析
6.4.3 模糊测试
6.4.4 人工代码审查
6.5 成功的关键因素
6.6 可交付成果
6.7 度量标准
6.8 本章小结
参考文献
第7章 发布(A5):SDL活动与最佳实践
7.1 A5策略一致性分析
7.2 漏洞扫描
7.3 渗透测试
7.4 开源许可审查
7.5 最终安全性审查
7.6 最终隐私性审查
7.7 成功的关键因素
7.8 可交付成果
7.9 度量标准
7.10 本章小结
参考文献
第8章 发布后支持(PRSA1~5)
8.1 合理调整软件安全组
8.1.1 正确的组织定位
8.1.2 正确的人
8.1.3 正确的过程
8.2 PRSA1:外部漏洞披露响应
8.2.1 发布后的PSIRT响应
8.2.2 发布后的隐私响应
8.2.3 优化发布后的第三方响应
8.3 PRSA2:第三方审查
8.4 PRSA3:发布后认证
8.5 PRSA4:新产品组合或云部署的内部审查
8.6 PRSA5:安全架构审查和基于工具评估当前、遗留以及并购的产品和解决方案
8.6.1 遗留代码
8.6.2 兼并和收购
8.7 成功的关键因素
8.8 可交付成果
8.9 度量标准
8.10 本章小结
参考文献
第9章 将SDL框架应用到现实世界中
9.1 引言
9.2 安全地构建软件
9.2.1 编写安全的代码
9.2.2 人工代码审查
9.2.3 静态分析
9.3 确定每个项目的正确行为
9.4 架构和设计
9.5 测试
9.5.1 功能测试
9.5.2 动态测试
9.5.3 攻击和渗透测试
9.5.4 独立测试
9.6 敏捷:冲刺
9.7 成功的关键因素和度量标准
9.7.1 安全编码培训计划
9.7.2 安全编码框架(API)
9.7.3 人工代码审查
9.7.4 独立代码审查和测试(专家或第三方)
9.7.5 静态分析
9.7.6 风险评估法
9.7.7 SDL和SDLC的集成
9.7.8 架构人才的发展
9.8 度量标准
9.9 本章小结
参考文献
第10章 集成:应用SDL防止现实的威胁
10.1 战略、战术和特定于用户的软件攻击
10.1.1 战略攻击
10.1.2 战术攻击
10.1.3 特定于用户的攻击
10.2 应用适当设计、管理和集中的SDL克服组织与业务挑战
10.3 软件安全组织的现状和影响力
10.4 通过合理的政府管理克服SDL审计和法规挑战
10.5 软件安全的未来预测
10.5.1 坏消息
10.5.2 好消息
10.6 总结
参考文献
附录 关键的成功因素、可交付成果、SDL模型每个阶段的指标
序
前言
作者简介
第1章 引论
1.1 软件安全的重要性和相关性
1.2 软件安全和软件开发生命周期
1.3 代码的质量与安全
1.4 SDL三个最重要的安全目标
1.5 威胁建模和攻击面验证
1.6 本章小结:期望从本书中学到什么
参考文献
第2章 安全开发生命周期
2.1 克服软件安全中的挑战
2.2 软件安全成熟度模型
2.3 ISO/IEC 27034:信息技术、安全技术、应用安全
2.4 其他SDL最佳实践的资源
2.4.1 SAFECode
2.4.2 美国国土安全软件保障计划
2.4.3 美国国家标准与技术研究院
2.4.4 MITRE公司公共计算机漏洞和暴露
2.4.5 SANS研究所高级网络安全风险
2.4.6 美国国防部网络安全与信息系统信息分析中心
2.4.7 CERT、Bugtraq和SecurityFocus
2.5 关键工具和人才
2.5.1 工具
2.5.2 人才
2.6 最小特权原则
2.7 隐私
2.8 度量标准的重要性
2.9 把SDL映射到软件开发生命周期
2.10 软件开发方法
2.10.1 瀑布开发
2.10.2 敏捷开发
2.11 本章小结
参考文献
第3章 安全评估(A1):SDL活动与最佳实践
3.1 软件安全团队提早参与项目
3.2 软件安全团队主持发现会议
3.3 软件安全团队创建SDL项目计划
3.4 隐私影响评估计划启动
3.5 安全评估(A1)成功的关键因素和度量标准
3.5.1 成功的关键因素
3.5.2 可交付成果
3.5.3 度量标准
3.6 本章小结
参考文献
第4章 架构(A2):SDL活动与最佳实践
4.1 A2策略一致性分析
4.2 SDL策略评估和范围界定
4.3 威胁建模/架构安全性分析
4.3.1 威胁建模
4.3.2 数据流图
4.3.3 架构威胁分析和威胁评级
4.3.4 风险缓解
4.4 开源选择
4.5 隐私信息收集和分析
4.6 成功的关键因素和度量标准
4.6.1 成功的关键因素
4.6.2 可交付成果
4.6.3 度量标准
4.7 本章小结
参考文献
第5章 设计和开发(A3):SDL活动与最佳实践
5.1 A3策略一致性分析
5.2 安全测试计划构成
5.3 威胁模型更新
5.4 设计安全性分析和检查
5.5 隐私实现评估
5.6 成功的关键因素和度量标准
5.6.1 成功的关键因素
5.6.2 可交付成果
5.6.3 度量标准
5.7 本章小结
参考文献
第6章 设计和开发(A4):SDL活动与最佳实践
6.1 A4策略一致性分析
6.2 安全测试用例执行
6.3 SDLC/SDL过程中的代码审查
6.4 安全分析工具
6.4.1 静态分析
6.4.2 动态分析
6.4.3 模糊测试
6.4.4 人工代码审查
6.5 成功的关键因素
6.6 可交付成果
6.7 度量标准
6.8 本章小结
参考文献
第7章 发布(A5):SDL活动与最佳实践
7.1 A5策略一致性分析
7.2 漏洞扫描
7.3 渗透测试
7.4 开源许可审查
7.5 最终安全性审查
7.6 最终隐私性审查
7.7 成功的关键因素
7.8 可交付成果
7.9 度量标准
7.10 本章小结
参考文献
第8章 发布后支持(PRSA1~5)
8.1 合理调整软件安全组
8.1.1 正确的组织定位
8.1.2 正确的人
8.1.3 正确的过程
8.2 PRSA1:外部漏洞披露响应
8.2.1 发布后的PSIRT响应
8.2.2 发布后的隐私响应
8.2.3 优化发布后的第三方响应
8.3 PRSA2:第三方审查
8.4 PRSA3:发布后认证
8.5 PRSA4:新产品组合或云部署的内部审查
8.6 PRSA5:安全架构审查和基于工具评估当前、遗留以及并购的产品和解决方案
8.6.1 遗留代码
8.6.2 兼并和收购
8.7 成功的关键因素
8.8 可交付成果
8.9 度量标准
8.10 本章小结
参考文献
第9章 将SDL框架应用到现实世界中
9.1 引言
9.2 安全地构建软件
9.2.1 编写安全的代码
9.2.2 人工代码审查
9.2.3 静态分析
9.3 确定每个项目的正确行为
9.4 架构和设计
9.5 测试
9.5.1 功能测试
9.5.2 动态测试
9.5.3 攻击和渗透测试
9.5.4 独立测试
9.6 敏捷:冲刺
9.7 成功的关键因素和度量标准
9.7.1 安全编码培训计划
9.7.2 安全编码框架(API)
9.7.3 人工代码审查
9.7.4 独立代码审查和测试(专家或第三方)
9.7.5 静态分析
9.7.6 风险评估法
9.7.7 SDL和SDLC的集成
9.7.8 架构人才的发展
9.8 度量标准
9.9 本章小结
参考文献
第10章 集成:应用SDL防止现实的威胁
10.1 战略、战术和特定于用户的软件攻击
10.1.1 战略攻击
10.1.2 战术攻击
10.1.3 特定于用户的攻击
10.2 应用适当设计、管理和集中的SDL克服组织与业务挑战
10.3 软件安全组织的现状和影响力
10.4 通过合理的政府管理克服SDL审计和法规挑战
10.5 软件安全的未来预测
10.5.1 坏消息
10.5.2 好消息
10.6 总结
参考文献
附录 关键的成功因素、可交付成果、SDL模型每个阶段的指标