原创 安全软件开发最佳实践指南

2022-12-9 09:40 983 4 4 分类: MCU/ 嵌入式

在任何新的软件开发项目开始时都应考虑软件安全性。开始一项工作可能会让人望而却步,因为需要做出许多决定,并且必须仔细考虑。这通常包括定义项目需求、选择正确的流程、选择正确工具和确保软件安全。

出于这个原因,我们组织了一个循序渐进的指南,帮助您完成新项目中最耗时和最困难的挑战,以确保您的项目取得成功。

安全软件开发最佳实践


安全的软件开发最佳实践可以简单地分为四个主要部分:
1. 了解您的项目要
2. 定义软件开发流程
3. 为项目选择合适的工具
4. 设置 DevSecOps

SAST 工具(如 Klocwork)可以帮助您满足每个部分的建议指南。

了解您的项目要求

在项目开始时,您需要考虑几个因素 。通过查看这些内容,它将帮助您更好地了解您的项目要求。

概述项目
花时间了解项目本身,并提出有助于指导整个开发生命周期决策的问题。像这样的问题:
正在开发什么类型的项目?(嵌入式、云服务、前端/后端软件等)
这个项目面向哪个行业?( 汽车 航空航天 、企业、 医疗 金融 等)
软件将如何使用以及在什么设置下使用?(企业、中小企业、B2BB2C 等)

定义项目愿景
对应用程序将提供的内容有一个愿景,有助于为工作树立一颗指路明灯。通过制定客户问题、痛点以及应用程序将如何解决这些问题的明确规范,将有助于确保您提供正确的解决方案。

确定合规性要求
确定作为项目行业、供应链、业务或客户要求的一部分是否存在代码合规性要求。

此外,您还需要确定需要什么级别的信息安全、功能安全和质量合规。这可能包括编码标准,例如:
• CWE
• CERT
• CVE
• OWASP
• DISA-STIG
• MISRA
• AUTOSAR

从项目一开始就选择并遵循一个标准将减少将来的合规性难题。

选择灵活的编程语言
确保您的编程语言(无论是 CC++C#Java JavaScript-最适合您的项目。选择最合适的编码语言可为您带来以下好处:
易于开发
代码的可维护性
接触熟练的开发人员
明确的编码标准和最佳实践

您选择的语言可以决定您的软件是否保持价值和活力。

开发代码设计
花时间制定设计规范。通过这样做,您能够验证系统逻辑,确定所有组件是否将一起正确执行,并帮助确保软件安全。这可能意味着成功发布和代价高昂的重新设计之间的区别。

建立代码架构
规划您的代码库以确保其井井有条。请务必考虑以下事项:
文件命名约定
为项目定义模块
层次和结构

通过提前完成这项工作,您可以为开发人员提供一个清晰的模板去遵循,以便将来更轻松地进行维护。

定义您的软件开发流程

虽然您的开发过程对于您的项目需求和要求是独一无二的,但我们建议您考虑以下几点:

确定需要实施哪些软件安全最佳实践
根据行业的不同,您的开发项目可能需要遵循特定的最佳实践和标准。此时,您应该使项目要求与开发过程保持一致。这可能包括遵循功能安全标准 (如 IEC 61508 )和遵循安全编码实践(如 CERT CWE )。

静态分析器 (如 Klocwork )可以帮助执行项目可能需要的任何标准、最佳实践和条件。

与开发方法保持一致
无论您的开发过程是Agile/Waterfall, Scrum/Kanban还是您当前可能拥有的任何其他过程,都无关紧要。重要的是,您需要在适合您的业务、开发人员和开发团队打算交付项目的方式的开发流程上保持一致。

在方法上保持一致的目的是拥有一个确保组织和沟通以及帮助防止开发过程中出现问题的过程。

组织您的环境设置
一般来说,确定并创建项目所需的环境以确保整个团队使用相同的设置非常重要。最佳做法是,应为以下对象设置单独的环境:开发、用户验收测试 UAT)、阶段化和生产。

使用存储库工具
使用版本控制工具(如 Helix Core )建立源代码存储库。这使您的开发团队能够:
花更少的时间处理工具和流程。
停止在手动工作流程上浪费时间,使他们能够重新开始编码。
高效处理数以万计的文件以及数 PB 级的数据。
将代码中的更改内容与更改原因联系起来。

除了代码存储库之外,还应考虑使用其他工具或流程来存储和跟踪其他与项目相关的内容。这包括:
将项目使用的工具和组件保留在整个团队可以轻松使用的地方。
为计划、文档和开发人员入职提供中心位置。
在项目管理软件(如 Helix ALM )或问题跟踪软件中定义工作任务。

通过建立这些存储库,您可以帮助确保您的开发高效、内容安全,并且知识易于快速上手新开发人员。

通过安全编码实践强制实施软件安全性
通过遵循安全编码实践,将安全实施构建到开发过程中,并使用安全编码工具帮助强制实施合规性。此外,为您的团队提供安全培训和学习材料,以帮助发展安全文化。 SAST 工具(如 Klocwork )可以帮助解决这些问题。

将检查合并到开发管道中
在整个开发管道中实施安全检查有助于强制实施良好的编码实践。在开发代码时,请务必注意安全,建议您在开发人员的 IDE CI/CD 管道 中以及在持续集成构建期间使用 SAST 扫描。

出于测试和重构目的,请确保开发人员正在编写单元测试,并且质量保证正在编写功能测试。通常,请考虑所有可能的测试策略,并确保尽可能创建并自动化安全性和其他测试。

为您的项目任务和功能定义完成
即使任务或功能看起来已完成并在开发人员的桌面上编译,但事实并非如此。你需要有一个明确的流程来定义工作——从头到尾。

最佳做法包括:
需求捕获
工作范围
定义验收标准
为代码开发单元和功能测试用例
进行 同行代码评审
集成测试、安全测试以及从所有阶段到最终环境测试的自动化

鼓励反馈和沟通
团队和开发人员之间的反馈和沟通对于项目的成功至关重要。

重要的是,您的开发人员能够从代码提交中获得快速反馈,以便他们能够及早解决编码问题,并为项目干系人提供有关项目进度、指标和潜在风险的见解。

在自动化之外,为开发人员提供足够的时间进行代码审查、规划和回顾非常重要。这些都将有助于确保在消除通信障碍时保持高开发速度。

为您的项目选择合适的工具

项目的一个重要部分是选择正确的工具。工具选择很重要,因为它有助于标准化您的项目,并使团队中的每个人都能说同一种语言。这为以下方面提供了整个团队的好处:
生产力
公共知识
测试和调试
入职

为了帮助确保为团队选择最有效的工具集,请考虑以下准则:
研究和查看所有工具选项,并根据项目和团队要求对其进行评估。
了解工具选择的成熟度以及可用的支持类型,例如技术支持、帮助资源和主动维护。
考虑工具、团队的经验水平以及招聘新开发人员的能力将受到怎样的影响。
检查工具集之间的兼容性。

无论您选择哪种工具集,我们都建议它包括以下内容:
代码存储库和版本控制 ,用于跟踪和管理对源代码、数字资产和大型二进制文件的更改。
静态代码分析器和 SAST 工具,用于强制实施安全编码实践,并识别缺陷、漏洞和合规性问题。
应用程序生命周期管理工具在项目的整个 应用程序生命周期 管理中提供端到端的可追溯性。

为您的软件开发项目设置 DevSecOps

DevOps 的速度和规模 与安全编码实践相结合 DevSecOps 是必不可少的软件安全最佳实践。通过遵循 DevSecOps 方法,您可以:
尽可能多地自动化流程安全性、配置、管理、测试等。这将为开发人员腾出时间专注于新的代码和功能。
定义成功/失败指标,并主动监控和报告项目结果。这有助于您更快地发现问题和漏洞,做出更明智的决策,并在整个应用程序中强制实施项目要求。
采取措施保护您的基础架构。安全性不仅对您的最终产品很重要,而且对您公司的程序和政策也很重要。确保您从整体上考虑安全性,并从上到下促进安全文化。
持续监控和实施软件安全合规性。将安全工具(如 SAST DAST SCA)集成到 DevSecOps 管道中,以便在整个开发生命周期中主动跟踪和实施安全性。

选择Perforce工具以确保项目成功
Klocwork SAST for C,C++,C#,Java,JavaScript,Python,and Kotlin 可识别安全性、质量和可靠性问题。这有助于强制遵守编码标准,以确保您的代码免受安全漏洞的影响。Klocwork 旨在轻松扩展到任何规模的项目,使您能够在编写代码时自动进行源代码分析。

此外,Klocwork的差异分析使您能够仅对已更改的文件执行快速增量分析 ,同时提供与完整项目扫描结果相同的结果。这确保了尽可能短的分析时间。

通过使用Klocwork,您还将获得以下好处:
在开发早期检测代码漏洞、合规性问题和规则冲突。这有助于加快代码审查和手动测试工作。
执行行业和编码标准,包括 CWE CERT OWASP DISA STIG
报告一段时间内和跨产品版本的合规性。

了解 Klocwork 如何帮助确保您的下一个项目取得成功。注册免费试用版。

作者: 北汇信息, 来源:面包板社区

链接: https://mbb.eet-china.com/blog/uid-me-3998886.html

版权声明:本文为博主原创,未经本人允许,禁止转载!

PARTNER CONTENT

文章评论0条评论)

登录后参与讨论
EE直播间
更多
我要评论
0
4
关闭 站长推荐上一条 /3 下一条