 描述
一个对象包含一个公共静态字段,不是决赛,这可能允许它被修改以意想不到的方式。
 扩展描述
公共静态变量可以没有一个访问器读取和改变应用程序中没有任何类的突变。
 的关系
 背景细节
当一个字段声明公共但不是最后,字段可以被任意读取和写入Java代码。
 模式的介绍
不同模式的引入提供了信息如何以及何时可以纳入这一弱点。生命周期的阶段识别点的介绍可能发生,而相关的报告提供了一个典型的场景介绍在给定的阶段。
 常见的后果
这个表指定不同的个人相关后果的弱点。标识应用程序范围的安全领域侵犯,而影响了负面的技术影响,如果敌人成功利用这个弱点。可能提供的信息如何可能的具体结果预计将看到列表中相对于其它后果。例如,可能会有高可能性,缺点将被利用来实现一定的影响,但较低的可能性,它将被利用来实现不同的影响。
范围 |
影响 |
可能性 |
完整性
|
对象可能被篡改。 |
|
保密
|
对象可能允许对象被阅读。 |
|
 利用的可能性
 示范例子
示例1
下面的示例使用一个公共静态字符串变量包含属性的名称/为应用程序配置文件。
类SomeAppClass {
公众:
静态字符串appPropertiesConfigFile = " app / properties.config”;
…
}
公开课SomeAppClass {
公共静态字符串appPropertiesFile =“app / Application.properties”; …
}
有一个公共静态变量不显著最后(常数)可能允许变量改变不是由应用程序。在本例中,字符串变量可以被修改来表示另一个不存在的属性文件,可能会导致应用程序崩溃或引起意想不到的行为。
类SomeAppClass {
公众:
静态常量字符串appPropertiesConfigFile =“app / properties.config”;
…
}
公开课SomeAppClass {
公共静态最终字符串appPropertiesFile =“app / Application.properties”; …
}
 潜在的缓解措施
阶段:体系结构和设计
清楚地识别范围为所有关键数据元素,包括他们是否应该被认为是静态的。 |
实施阶段:
做任何静态字段私人和常数。
一个常数字段是用关键字“常量”在C / c++和Java中“最后”
|
 会员资格
这MemberOf关系表显示额外CWE类别和视图引用这个弱点作为成员。这些信息通常是有用的在理解一个弱点符合外部信息源的上下文中。
 分类法映射
映射分类名称 |
节点ID |
适合 |
映射节点名 |
扣 |
|
|
内部缓冲区溢出静态 |
CERT甲骨文安全Java编码标准(2011) |
OBJ10-J |
|
不要使用公共静态非最终变量 |
软件故障模式 |
SFP28 |
|
意外的访问点 |
 引用
|