cwe - 336:同样的种子在伪随机数发生器(PRNG)
描述
一个伪随机数发生器(PRNG)每次使用相同的种子产品初始化。
扩展描述
鉴于prng的确定性性质,使用相同的种子为每个初始化将导致在相同的顺序相同的输出。如果攻击者可以猜(或认识)种子,然后攻击者能够确定的随机数PRNG的产生。
的关系
此表显示了弱点和高水平类别相关的这一弱点。这些关系被定义为ChildOf、ParentOf MemberOf,并洞察类似项目可能存在的在较高和较低的抽象级别。此外,关系如PeerOf和CanAlsoBe定义显示类似的弱点,用户可能想要探索。
相关的视图”研究概念”(cwe - 1000)
自然 |
类型 |
ID |
的名字 |
ChildOf |
Base -一个弱点,仍主要是独立的资源或技术,但有足够的细节来提供特定的检测和预防方法。基础水平的弱点通常描述问题的2或3以下维度:行为、财产、技术、语言,和资源。 |
335年 |
不正确的使用伪随机数生成器的种子(PRNG) |
此表显示了弱点和高水平类别相关的这一弱点。这些关系被定义为ChildOf、ParentOf MemberOf,并洞察类似项目可能存在的在较高和较低的抽象级别。此外,关系如PeerOf和CanAlsoBe定义显示类似的弱点,用户可能想要探索。
相关视图”架构概念”(cwe - 1008)
自然 |
类型 |
ID |
的名字 |
MemberOf |
类别——CWE条目包含一组其他条目,共享一个共同的特点。 |
1013年 |
加密数据 |
模式的介绍
不同模式的引入提供了信息如何以及何时可以纳入这一弱点。生命周期的阶段识别点的介绍可能发生,而相关的报告提供了一个典型的场景介绍在给定的阶段。
阶段 |
请注意 |
实现 |
实现:造成这一弱点在建筑安全策略的实施。 |
常见的后果
这个表指定不同的个人相关后果的弱点。标识应用程序范围的安全领域侵犯,而影响了负面的技术影响,如果敌人成功利用这个弱点。可能提供的信息如何可能的具体结果预计将看到列表中相对于其它后果。例如,可能会有高可能性,缺点将被利用来实现一定的影响,但较低的可能性,它将被利用来实现不同的影响。
示范例子
示例1
下面的代码使用一个统计PRNG生成账户id。
私有静态最终长种子= 1234567890; 公共int generateAccountID () {
随机随机= new随机(种子); 返回random.nextInt (); }
因为程序使用相同的种子值每PRNG的调用,其值是可预测的,使系统容易受到攻击。
示例2
这段代码试图随机生成唯一标识用户的会话。
函数generateSessionID(美元userID) {
将srand ($ userID); 返回rand (); }
因为PRNG的种子总是用户的ID,会话ID将永远是相同的。攻击者可能因此预测任何用户的会话ID和劫持会话。
如果用户id生成的顺序,或局限于一个狭窄的范围值,那么这个例子也展示一个小种子空间(cwe - 339)。
潜在的缓解措施
阶段:体系结构和设计
不重用PRNG种子。根据需要考虑一个定期的PRNG补种本身从一个高质量的伪随机输出,如硬件设备。 |
阶段:体系结构和设计;需求
|
检测方法
自动静态分析
自动静态分析,通常被称为静态应用程序安全性测试(科协),可以找到一些实例的这个弱点分析源代码或二进制/编译后的代码,而不必执行它。通常情况下,这是通过建立一个模型的数据流和控制流,然后寻找潜在攻击模式,连接“源”与“下沉”(输入)的起源(目的地数据与外部组件交互,较低的层,如操作系统,等等)。
|
会员资格
这MemberOf关系表显示额外CWE类别和视图引用这个弱点作为成员。这些信息通常是有用的在理解一个弱点符合外部信息源的上下文中。
脆弱性映射笔记
用法:允许
(CWE ID可以用来映射到现实世界的漏洞) |
原因:可接受的使用 |
理由是: 这个CWE条目是变体的抽象级别,这是一个首选的抽象级别映射到漏洞的根本原因。 |
评论: 仔细阅读这两个名称和描述,以确保此映射是一个适当的配合。不要试图“力”映射到底层基础/变体只是遵守这首选的抽象级别。 |
笔记
维护
CWE 4.5,相关术语随机性,熵,和可预测性可以相差很大。在开发人员和其他社区,使用“随机性”。然而,在密码学,“熵”是不同的,通常隐含的测量。没有常用的定义,甚至在标准文件和加密文件。CWE的未来版本将试图定义这些术语,如果有必要,区分他们的方式适合不同的社区,但不会减少可用性CWE的映射,理解,或者其他场景。
分类法映射
映射分类名称 |
节点ID |
适合 |
映射节点名 |
千鸟 |
|
|
同样的种子PRNG |
CERT甲骨文安全Java编码标准(2011) |
MSC02-J |
|
产生强烈的随机数 |
引用
更多的信息是可用的,请编辑自定义过滤器或选择一个不同的过滤器。
|