Fundamentals of Secure Development
课程目标
辨识主要的软件安全因素。Identify major factors in the business, regulatory, and threat landscapes that drive the demand for software security.
辨识重要的安全模型等。Identify important security models, standards, and guidelines that provide a strategic roadmap for application security.
辨识软件开发流程中的安全实践和原则。Identify secure development practices and principles that correspond to each phase of the software development lifecycle.
Module Overview模块概述
This module explains the overriding importance of software security and the potential business consequences of developing and deploying insecure software.讲述了软件安全的最高的重要性以及不安全的软件开发和部署带来的潜在业务结果
Module Objectives模块目标
After completing this module, you’ll be able to:
Identify the difference between software security and network security. 认识到软件安全和网络安全的区别
Identify the business imperatives for software security, including: 认识到业务上对软件安全的必须性
What is Software Security?
Software security focuses on protecting information and resources made accessible by applications running on computer systems.软件安全是保护计算机应用可访问的信息和资源
Software security is often confused with network security. Network security focuses on the protection of an organization’s IT infrastructure—the servers and related equipment that control the flow of data between networked systems.网络安全是保护一个组织的IT基础设施,控制网络系统的数据流
Network security controls are typically insufficient to mitigate software security risks.网络安全控制通常不足以减轻软件安全风险
Software security attacks often occur at higher layers of operation, not visible to network security controls.软件安全攻击通常发生在较高层操作,对网络安全控制不可见。
The Security Imperative
Key reasons why organizations must develop and deploy secure software include:
High business costs of security breaches
Compliance and legal implications of security breaches
Customer expectations of security
An increasing threat landscape
The Business Costs of Software Security Breaches
Software security breaches expose organizations to various risks that result in the following direct and indirect costs:直接间接成本
Downtime and other operational losses if an application is hacked 停机时间和其他操作成本
Financial claims and settlements 财务索赔和结算
Compliance fines and penalties 合规罚款和处罚
Loss of investor and customer confidence 失去投资人和客户信心
Lost sales 销售额损失
Damage to reputation 声誉受损
McAfee estimates the global annual cost of cybercrime at over $400 billion dollars.*
*Source: Net Losses: Estimating the Global Cost of Cybercrime, June 2014, McAfee, Intel Security
Compliance and Legal Implications 合规和法律意义
Federal and state regulations mandate software security and require protection of sensitive customer data. 法规要求保护用户敏感数据
Even if an organization is not required by local regulations to develop secure software, they might still need to do so to conduct business in other states.就算本地没有要求,要在其他地方开展业务也会有要求
It is difficult, if not impossible, to ignore software security without incurring significant fines or loss of business. 重大罚款和业务损失
Customers Expect Secure Solutions 用户期望安全解决方案
Regulatory and legislative measures and the media have increased business awareness of the need for secure software and services. 监管,法规媒体提高了安全需求意识
Failure to develop and deliver secure software and services could damage your organization’s reputation, and drive business to your competitors. 失败的安全开发会影响声誉
An Increasing Threat Landscape 增长的威胁环境
In the past, hackers were motivated to attack systems and software to gain notoriety. Today, the number of attacks is increasing, and attackers are motivated by financial gains, political agendas, and corporate and international espionage.黑客以前是为了名声,现在是为了财,政以及作为间谍
Specialized hacking techniques are publicly documented and well understood by many. In addition, automated attack tools are freely available and accessible.专业的黑客技术已经被公开,自动黑客工具也很容易免费得到
This translates to a higher probability of being hacked, as well as higher expected costs for recovering from cyber attacks.这些意味着攻击可能性的提高和恢复成本的提高
Module Summary
In this module, you learned how software security differs from network security. 软件安全和网络安全的区别
You also learned the key reasons why organizations must develop secure software, including high business costs of security breaches, compliance and legal implications of security breaches, customer expectations of security, and a changing threat landscape. 为什么进行安全开发的关键原因
Module Overview
This module introduces models, standards, and guidelines that you can use to improve the security posture of your applications. These resources provide a roadmap to follow to design security into your applications. You don't need to become a security expert to use them.
Module Objectives
After completing this module, you will be able to:
Identify how security activities overlay the software development process.知道安全活动如何覆盖软件开发过程。
Identify the major models, standards, and guidelines of the application security industry, and how they can help you improve the security posture of your applications.知道应用程序安全行业的主要模型,标准和指南,以及它们如何帮助您提高应用程序的安全状态。
Fundamentals of Secure Development
作为开发,不需要成为安全专家,但是需要了解
介绍一些安全标准和提高安全的快速方法
但是关键在于保持对于安全知识的update,这些安全标准等能提高安全性,但不能让应用免疫于黑客攻击
SDLC,软件安全同样贯彻于软件生命周期的每一个过程中,Planning,Design,Development and Maintenacne,Implementation and Testing
关注OWASP Top 10的安全问题,它们是最常见的10种web应用的攻击方式,要让应用不受这些影响
微软的SDL流程,在每个阶段针对不同角色也有相关的安全性措施
CWE/SANS 25个最危险的软件错误,虽然是2011年的,但是对于现在依然有意义。
支付行业有标准14条PA-DSS
Do not retain full track data card verification code or PIN block data.
Protect stored cardholder data.
Provide secure authentication features.
Log payment application activity.
Develop secure payment applications.
Protect wireless transmissions.
Test payment applications to address vulnerabilities and maintain payment application updates.
Facilitate secure network implementation.
Do not allow cardholder data to be stored on a server connected to the Internet.
Facilitate secure remote access to payment application.
Encrypt sensitive traffic over public networks.
Encrypt all non-console administrative access.
Maintain a PA-DSS implementation guide for customers, resellers, and integrators.
Assign PA-DSS responsibilities for personnel, and maintain training programs for personnel,
customers, resellers, and integrators.
Cloud Security Alliance (CSA) Notorious Nine Report 对云计算威胁最大的前9个的 报告
2012年云安全联盟发布了10条大数据安全与挑战的报告
Secure computations in distributed programming frameworks
Security best practices for non-relational data stores
Secure data storage and transactions logs
Endpoint input validation/filtering
Real-time security monitoring
Scalable and composable privacy-preserving data mining and analytics
Cryptographically enforced data-centric security
Granular access control
Granular audits
Data provenance
OpenSAMM (The Software Assurance Maturity Model) 软件保证成熟度模型
BSIMM (Building Security In Maturity Model) 构建安全成熟度模型 不提供安全开发模型,提供参与组织的经验和课
BSIMM的安全框架SSF
Comprehensive Lightweight Application Security Process (CLASP) 是OWASP的一个产品。综合轻量级应用程序安全流程
The Common Criteria for Information Technology Security Evaluation (CC)信息技术安全评估的通用标准
In this module, you learned about the following secure development models, standards, and guidelines that help you efficiently improve your application security posture:
把安全实践结合到各软件流程中去
介绍每个流程中的关键风险,自己结合到流程中去
Planning阶段
合法性的安全需求
客户的安全需求
安全培训
合法性方面建议有个了解全局的律师
客户安全方面了解要保护什么资产,要遵守什么,需要什么样的服务质量,什么数据是机密的
安全培训方面选择适合这个项目的安全培训,具体情况见表格
Design阶段
减少攻击面
安全默认值
最少的特权
深度防御
分区
遵守规则
Threat Modeling 风险模型
攻击者中心
软件中心
资产中心
减少攻击面
去掉或关掉不必要的功能
如果不能关掉,保证模块被安全地配置
默认安全
系统的默认值就是安全的
最少特权
设计时,给予最小的权限集
如果有需要提高权限的情况,在这之后应该尽快恢复成原来最小的权限
这样就算应用被攻击者控制,也会带来较小的危害
深度防御
多层防御,就算一层被攻破,其他层也能保护
分区
将系统分成不同区间,不同区之间有安全边界
遵守政策
遵守安全政策
Implementation and Testing 阶段
应用安全的编码原则
输入检测
用安全的库
利用语言,编译器和平台的保护
执行代码 安全分析和审查
静态代码分析
二进制分析
手动代码安全审查
故障注入
漏洞扫描
渗透测试
输入检测
防止恶意输入
白名单
黑名单
使用精心验证过的库
在服务器端执行验证
用正则表达式实现白名单验证
使用标准的安全库
使用一些框架自带的安全配置,打开语言的安全检查功能
代码分析和代码审查
静态分析,二进制分析
代码审查要在早期做
静态分析分析源码,二进制分析分析编译出来的可执行文件
静态分析的优点:可以看大量代码,客观公正,技术成熟,更易调试
静态分析的缺点:语言限定,需要多个工具,产生错误判断,只能检测到实现的缺陷,不能检测业务逻缺陷
二进制分析优点:可以看大量代码,客观公正,比静态检查更准确
二进制分析缺点:不成熟,修复bug困难,语言限定,可能需要多个工具,产生错误判断,只能检查出实现的缺陷
代码审查类似于静态分析,由人来阅读检测代码,而非工具
优点:误判较少,可以发现实现,设计和业务逻辑的漏洞
缺点:耗时,不能大量做,会被人类的疲劳和错误影响,会有偏见,不客观
有介绍如何code review的资源
故障注入
编译时向代码注入
运行时注入
Fuzzing 模糊是一种常见的故障注入方法
漏洞扫描 用自动化工具扫描正在运行的程序
可以找到常见漏洞
仅限于找到被预编程以检测的协议和漏洞
找不到自定义和业务逻辑漏洞
渗透测试
可以自定义协议和业务逻辑
没办法达到自动检查代码的规模
精确性会受到人的疲劳,经验以及资源不足的影响
Deployment and Maintenance 阶段
最低权限部署
响应事件计划
补丁计划
最低权限 部署应用要给最低权限
响应安全事件
要有负责人和联系人,职责明确,内外沟通,验证事件和开发补丁
确保合法
软件补丁
总结模块在四个阶段要怎么做
Last updated