CWE

普遍的弱点

社区开发的软件和硬件弱点类型清单

2021 CWE最重要的硬件弱点
CWE前25个最危险的弱点
>CWE列表> cwe-单个字典定义(4.10)
ID

CWE-159:不当处理特殊元素的使用不当

弱点ID:159
抽象:班级
结构:简单的
查看自定义信息:
+描述
该产品无法正确过滤,删除,引用或以其他方式管理用户控制输入中特殊元素的无效使用,这可能会对其行为和完整性造成不利影响。
+关系
部分帮助该表显示了与该弱点相关的弱点和高级类别。这些关系定义为childof,parentof,ementof,并深入了解可能存在于较高和较低抽象水平的类似项目。此外,定义了诸如Peerof和Canalsobe之类的关系,以显示用户可能想要探索的类似弱点。
+与观点“研究概念”相关(CWE-1000)
自然 类型 ID 姓名
Childof 班级班级 - 以非常抽象的方式描述的弱点,通常与任何特定的语言或技术无关。比支柱弱点更具体,但比基本弱点更一般。班级弱点通常用以下维度的1或2来描述问题:行为,属性和资源。 138 特殊元素中和不当
父母 根据基础 - 仍然主要独立于资源或技术的弱点,但有足够的细节来提供特定的检测和预防方法。基本水平的弱点通常用以下维度的2或3来描述问题:行为,财产,技术,语言和资源。 166 不当处理缺失的特殊元素
父母 根据基础 - 仍然主要独立于资源或技术的弱点,但有足够的细节来提供特定的检测和预防方法。基本水平的弱点通常用以下维度的2或3来描述问题:行为,财产,技术,语言和资源。 167 处理其他特殊元素不当
父母 根据基础 - 仍然主要独立于资源或技术的弱点,但有足够的细节来提供特定的检测和预防方法。基本水平的弱点通常用以下维度的2或3来描述问题:行为,财产,技术,语言和资源。 168 不当处理不一致的特殊元素
+介绍模式
部分帮助引言的不同模式提供了有关如何以及何时引入这种弱点的信息。该阶段识别可能发生介绍的生命周期中的一个点,而音符提供了与给定阶段中引言有关的典型情况。
阶段 笔记
执行
+适用的平台
部分帮助该清单显示了可能出现的弱点的可能区域。这些可能适用于特定的命名语言,操作系统,体系结构,范式,技术或一类此类平台。该平台与给定弱点出现在该实例的频率一起列出。

语言

班级:不是特定语言的(不确定的患病率)

+常见后果
部分帮助该表指定与弱点相关的不同个人后果。该范围确定了违反的应用程序安全区域,而影响描述了如果对手成功利用这一弱点,就会产生负面的技术影响。其可能性提供了有关预期相对于列表中其他后果的特定后果的可能性的信息。例如,可能会利用弱点来实现一定的影响,但很可能会利用它来实现不同的影响。
范围 影响 可能性
正直

技术影响:意外状态

+潜在的缓解
开发人员应预测,将在其软件系统的输入向量中注入/删除/操纵特殊元素。使用适当的派遣者和允许名单的组合来确保系统处理有效,预期和适当的输入。

阶段:实施

策略:输入验证

假设所有输入都是恶意的。使用“接受已知的好的”输入验证策略,即使用严格符合规格的可接受输入列表。拒绝任何不严格符合规格的输入,或将其转换为可以做的事物。

执行输入验证时,请考虑所有潜在的相关属性,包括长度,输入类型,可接受值的全部范围,缺失或额外的输入,语法,跨相关字段的一致性以及符合业务规则的一致性。作为业务规则逻辑的一个示例,“船”可能在句法上有效,因为它仅包含字母数字字符,但是如果仅预期输入包含诸如“红色”或“蓝色”之类的颜色,则无效。

不要仅仅依靠寻找恶意或畸形的输入。这可能会错过至少一个不良的输入,尤其是如果代码的环境发生变化。这可以为攻击者提供足够的空间来绕过预期的验证。但是,拒绝者对于检测潜在攻击或确定哪些投入是如此畸形以至于应直接拒绝。

阶段:实施

策略:输出编码

尽管使用动态生成的查询字符串,代码或将控制和数据混合在一起的命令有风险,但有时可能是不可避免的。适当地引用论点并逃脱这些参数中的任何特殊字符。最保守的方法是逃避或过滤所有不通过极严格的允许列表(例如所有不是字母数字或空白空间的字符)。如果仍然需要一些特殊的字符,例如空白空间,请在逃脱/过滤步骤后用引号包裹每个参数。小心论证注入(CWE-88)。

阶段:实施

策略:输入验证

在经过验证之前CWE-180)。确保应用程序不会解码相同的输入两次(CWE-174)。此类错误可以用来绕过允许列表验证方案,通过检查危险输入后进行检查。
+会员资格
部分帮助此成员关系表显示了其他CWE类别和视图,将此弱点称为成员。该信息通常可用于理解弱点适合外部信息源的何处。
自然 类型 ID 姓名
成员 类别类别 - 包含共享共同特征的其他条目的CWE条目。 990 SFP辅助群集:污染输入的命令
+笔记

术语

基本弱点的精确术语不存在。因此,这些弱点使用与操纵相关的术语。

研究差距

定制的语言和语法,即使是特定产品的语法,也是与特殊元素相关的弱点的潜在来源。但是,大多数研究人员都专注于最常用的数据传输表示,例如HTML和SQL。任何常用的代表都可能是弱点的丰富来源。鼓励研究人员调查先前未开发的表示。

维护

该条目的儿童名单远非完整。但是,特殊元素的类型可能过于精确,无法在CWE中使用。
+分类映射
映射的分类名称 节点ID 合身 映射的节点名称
plover 常见的特殊元素操纵
软件故障模式 SFP24 污染输入到命令
+内容历史记录
+提交
提交日期 提交者 组织
2006-07-19 plover
+修改
修改日期 修饰符 组织
2008-07-01 埃里克·达奇(Eric Dalci) 雪茄
更新的势_METIGATIONS,time_of_introduction
2008-09-08 CWE内容团队 MITER
更新的关系,其他_notes,分类_mappings
2009-07-27 CWE内容团队 MITER
更新的势_MINEIGATIONS
2009-10-29 CWE内容团队 MITER
更新的维护_notes,其他_notes,terminology_notes
2011-03-29 CWE内容团队 MITER
更新的描述,势_MITIGATIONS
2011-06-01 CWE内容团队 MITER
更新的common_cconsquences
2011-06-27 CWE内容团队 MITER
更新的common_cconsquences
2012-05-11 CWE内容团队 MITER
更新的关系
2012-10-30 CWE内容团队 MITER
更新的势_MINEIGATIONS
2014-06-23 CWE内容团队 MITER
更新其他_notes
2014-07-30 CWE内容团队 MITER
更新的关系,分类_mappings
2017-05-03 CWE内容团队 MITER
更新的势_MINEIGATIONS
2017-11-08 CWE内容团队 MITER
更新了适用的_platforms,关系
2020-02-24 CWE内容团队 MITER
更新的描述,名称,势_METIGATIONS,关系
2020-06-25 CWE内容团队 MITER
更新的势_MINEIGATIONS
2021-03-15 CWE内容团队 MITER
更新的维护_notes
+先前的输入名称
改变日期 先前的输入名称
2008-04-11 常见的特殊元素操纵
2020-02-24 未能消毒特殊元素
提供更多信息 - 请选择其他过滤器。
页面最后更新:2023年1月31日