CWE-478: Missing Default Case in Multiple Condition Expression

Base Draft Simple

CWE版本: 4.18

更新日期: 2025-09-09

弱点描述

The code does not have a default case in an expression with multiple conditions, such as a switch statement.

扩展描述

If a multiple-condition expression (such as a switch in C) omits the default case but does not consider or handle all possible values that could occur, then this might lead to complex logical errors and resultant weaknesses. Because of this, further decisions are made based on poor information, and cascading failure results. This cascading failure may result in any number of security issues, and constitutes a significant failure in the system.

常见后果

影响范围: Integrity

技术影响: Varies by Context Alter Execution Logic

说明: Depending on the logical circumstances involved, any consequences may result: e.g., issues of confidentiality, authentication, authorization, availability, integrity, accountability, or non-repudiation.

潜在缓解措施

阶段: Implementation

描述: Ensure that there are no cases unaccounted for when adjusting program flow or values based on the value of a given variable. In the case of switch style statements, the very simple act of creating a default case can, if done correctly, mitigate this situation. Often however, the default case is used simply to represent an assumed option, as opposed to working as a check for invalid input. This is poor practice and in some cases is as bad as omitting a default case entirely.

检测方法

方法: Automated Static Analysis

Automated static analysis, commonly referred to as Static Application Security Testing (SAST), can find some instances of this weakness by analyzing source code (or binary/compiled code) without having to execute it. Typically, this is done by building a model of data flow and control flow, then searching for potentially-vulnerable patterns that connect "sources" (origins of input) with "sinks" (destinations where the data interacts with external components, a lower layer such as the OS, etc.)

有效性: High

引入模式

阶段 说明
Implementation -

适用平台

编程语言
C (Undetermined) C++ (Undetermined) Java (Undetermined) C# (Undetermined) Python (Undetermined) JavaScript (Undetermined)

分类映射

分类名称 条目ID 条目名称 映射适配度
CLASP - Failure to account for default case in switch -
Software Fault Patterns SFP4 Unchecked Status Condition -
关键信息

CWE ID: CWE-478

抽象级别: Base

结构: Simple

状态: Draft

相关弱点