cwe - 1282: Assumed-Immutable数据存储在可写内存
描述
不可变数据,如第一阶段引导装载程序、设备标识符,和“写一次”配置设置存储在可写内存可以re-programmed或更新。
扩展描述
安全服务,如安全的引导,身份验证的代码和数据,和设备认证都需要资产,如第一阶段引导装载程序、公钥,金色的哈希摘要等隐式可信。将这些资产存储在只读存储器(ROM),保险丝或一次性可编程(OTP)存储器提供了强有力的完整性保证,并提供一个根的信任来保护系统的其余部分。安全丢失如果资产被认为是不可变的可以修改。
的关系
模式的介绍
不同模式的引入提供了信息如何以及何时可以纳入这一弱点。生命周期的阶段识别点的介绍可能发生,而相关的报告提供了一个典型的场景介绍在给定的阶段。
阶段 |
请注意 |
实现 |
钥匙、代码、配置设置和其他数据应该在写一次程序或只读存储器代替可写内存。 |
常见的后果
这个表指定不同的个人相关后果的弱点。标识应用程序范围的安全领域侵犯,而影响了负面的技术影响,如果敌人成功利用这个弱点。可能提供的信息如何可能的具体结果预计将看到列表中相对于其它后果。例如,可能会有高可能性,缺点将被利用来实现一定的影响,但较低的可能性,它将被利用来实现不同的影响。
示范例子
示例1
加密哈希函数通常用于创建独特的固定长度的摘要用于确保代码的完整性和钥匙。黄金消化存储在设备上,而消化从数据验证计算。如果摘要匹配,数据没有被恶意修改。如果攻击者可以修改黄金消化然后他们有能力存储任意数据,通过验证检查。哈希摘要用于验证公钥和早期阶段引导代码应该是不可变的,最强的保护提供的硬件不变性。
潜在的缓解措施
实施阶段:
所有不变的代码或数据应存入ROM或写一次内存。 |
笔记
维护
这个条目仍处于开发阶段,将继续看到更新和内容的改进。
|