Goal Reached Thanks to every supporter — we hit 100%!

Goal: 1000 CNY · Raised: 1000 CNY

100.0%

CWE-121 (栈缓冲区溢出) — Vulnerability Class 2533

2533 vulnerabilities classified as CWE-121 (栈缓冲区溢出). AI Chinese analysis included.

CWE-121 represents a critical memory safety weakness where program data exceeds the allocated bounds of a stack-allocated buffer, corrupting adjacent memory structures. Attackers typically exploit this vulnerability by injecting malicious payloads that overwrite the function’s return address or saved frame pointer, thereby hijacking control flow to execute arbitrary code with the privileges of the compromised process. This exploitation is particularly dangerous because stack buffers are local variables, making the attack surface common in low-level languages like C and C++. Developers mitigate this risk by enforcing strict input validation, utilizing safe string handling functions that prevent unbounded writes, and adopting modern programming languages with automatic memory management. Additionally, implementing compiler-level protections such as stack canaries and Address Space Layout Randomization significantly raises the barrier for successful exploitation, ensuring system integrity remains intact against buffer overflow attempts.

MITRE CWE Description
A stack-based buffer overflow condition is a condition where the buffer being overwritten is allocated on the stack (i.e., is a local variable or, rarely, a parameter to a function).
Common Consequences (3)
AvailabilityModify Memory, DoS: Crash, Exit, or Restart, DoS: Resource Consumption (CPU), DoS: Resource Consumption (Memory)
Buffer overflows generally lead to crashes. Other attacks leading to lack of availability are possible, including putting the program into an infinite loop.
Integrity, Confidentiality, Availability, Access ControlModify Memory, Execute Unauthorized Code or Commands, Bypass Protection Mechanism
Buffer overflows often can be used to execute arbitrary code, which is usually outside the scope of a program's implicit security policy.
Integrity, Confidentiality, Availability, Access Control, OtherModify Memory, Execute Unauthorized Code or Commands, Bypass Protection Mechanism, Other
When the consequence is arbitrary code execution, this can often be used to subvert any other security service.
Mitigations (5)
Operation, Build and CompilationUse automatic buffer overflow detection mechanisms that are offered by certain compilers or compiler extensions. Examples include: the Microsoft Visual Studio /GS flag, Fedora/Red Hat FORTIFY_SOURCE GCC flag, StackGuard, and ProPolice, which provide various mechanisms including canary-based detection and range/index checking. D3-SFCV (Stack Frame Canary Validation) from D3FEND [REF-1334] discusses…
Effectiveness: Defense in Depth
Architecture and DesignUse an abstraction library to abstract away risky APIs. Not a complete solution.
ImplementationImplement and perform bounds checking on input.
ImplementationDo not use dangerous functions such as gets. Use safer, equivalent functions which check for boundary errors.
Operation, Build and CompilationRun or compile the software using features or extensions that randomly arrange the positions of a program's executable and libraries in memory. Because this makes the addresses unpredictable, it can prevent an attacker from reliably jumping to exploitable code. Examples include Address Space Layout Randomization (ASLR) [REF-58] [REF-60] and Position-Independent Executables (PIE) [REF-64]. Imported…
Effectiveness: Defense in Depth
Examples (2)
While buffer overflow examples can be rather complex, it is possible to have very simple, yet still exploitable, stack-based buffer overflows:
#define BUFSIZE 256 int main(int argc, char **argv) { char buf[BUFSIZE]; strcpy(buf, argv[1]); }
Bad · C
This example takes an IP address from a user, verifies that it is well formed and then looks up the hostname and copies it into a buffer.
void host_lookup(char *user_supplied_addr){ struct hostent *hp; in_addr_t *addr; char hostname[64]; in_addr_t inet_addr(const char *cp); /*routine that ensures user_supplied_addr is in the right format for conversion */ validate_addr_form(user_supplied_addr); addr = inet_addr(user_supplied_addr); hp = gethostbyaddr( addr, sizeof(struct in_addr), AF_INET); strcpy(hostname, hp->h_name); }
Bad · C
CVE IDTitleCVSSSeverityPublished
CVE-2024-37008 Stack-based Overflow Vulnerability in Revit Software — Revit 7.8 High2024-08-21
CVE-2024-7013 Panasonic Control FPWIN Pro 安全漏洞 — Control FPWIN Pro 7.8 High2024-08-21
CVE-2024-7909 TOTOLINK EX1200L cstecgi.cgi setLanguageCfg stack-based overflow — EX1200L 8.8 High2024-08-18
CVE-2024-7908 TOTOLINK EX1200L cstecgi.cgi setDefResponse stack-based overflow — EX1200L 8.8 High2024-08-18
CVE-2024-41852 Adobe Indesign 2024 AVI File Parsing Stack Based Buffer Overflow — InDesign Desktop 7.8 High2024-08-14
CVE-2024-39389 Adobe Indesign PDF File Parsing Stack Based Buffer Overflow Remote Code Execution Vulnerability — InDesign Desktop 7.8 High2024-08-14
CVE-2024-7707 Tenda FH1206 HTTP POST Request SafeEmailFilter formSafeEmailFilter stack-based overflow — FH1206 8.8 High2024-08-13
CVE-2024-7615 Tenda FH1206 fromSafeUrlFilter stack-based overflow — FH1206 8.8 High2024-08-08
CVE-2024-7614 Tenda FH1206 qossetting fromqossetting stack-based overflow — FH1206 8.8 High2024-08-08
CVE-2024-39791 Vonets WiFi Bridges Stack-based Buffer Overflow — VAR1200-H 10.0 Critical2024-08-08
CVE-2024-7581 Tenda A301 WifiBasicSet formWifiBasicSet stack-based overflow — A301 8.8 High2024-08-07
CVE-2024-7502 Delta Electronics DIAScreen Stack-Based Buffer Overflow — DIAScreen 7.8 High2024-08-06
CVE-2024-7547 oFono SMS Decoder Stack-based Buffer Overflow Privilege Escalation Vulnerability — oFono 8.4 -2024-08-05
CVE-2024-7539 oFono CUSD Stack-based Buffer Overflow Code Execution Vulnerability — oFono 8.4 -2024-08-05
CVE-2024-7538 oFono CUSD AT Command Stack-based Buffer Overflow Code Execution Vulnerability — oFono 7.8 -2024-08-05
CVE-2024-7441 Vivotek SD9364 httpd read stack-based overflow — SD9364 8.8 High2024-08-03
CVE-2024-7439 Vivotek CC8160 httpd read stack-based overflow — CC8160 8.8 High2024-08-03
CVE-2024-40723 CHANGING Information Technology HWATAIServiSign Windows Version - Stack-based Buffer Overflow — HWATAIServiSign Windows Version 4.3 Medium2024-08-02
CVE-2024-40722 CHANGING Information Technology TCBServiSign Windows Version - Stack-based Buffer Overflow — TCBServiSign Windows Version 4.3 Medium2024-08-02
CVE-2024-31203 Plug and Track Thermoscan IP 安全漏洞 — Thermoscan IP 3.3 Low2024-07-31
CVE-2024-39950 Dahua NVR 安全漏洞 — NVR4XXX and IPC-HX8XXX 8.6 High2024-07-31
CVE-2024-7152 Tenda O3 setMacFilterList fromSafeSetMacFilter stack-based overflow — O3 8.8 High2024-07-27
CVE-2024-7151 Tenda O3 setMacFilter fromMacFilterSet stack-based overflow — O3 8.8 High2024-07-27
CVE-2024-38509 Lenovo XClarity Controller 安全漏洞 — XClarity Controller 7.2 High2024-07-26
CVE-2024-5602 Stack-based Buffer Overflow Vulnerability in NI I/O Trace Tool — IO Trace Tool 7.8 High2024-07-23
CVE-2024-6965 Tenda O3 fromVirtualSet stack-based overflow — O3 8.8 High2024-07-22
CVE-2024-6964 Tenda O3 fromDhcpSetSer stack-based overflow — O3 8.8 High2024-07-22
CVE-2024-6963 Tenda O3 formexeCommand stack-based overflow — O3 8.8 High2024-07-22
CVE-2024-6962 Tenda O3 formQosSet stack-based overflow — O3 8.8 High2024-07-21
CVE-2024-6744 Cellopoint Secure Email Gateway 安全漏洞 — Secure Email Gateway 9.8 Critical2024-07-15

Vulnerabilities classified as CWE-121 (栈缓冲区溢出) represent 2533 CVEs. The CWE taxonomy describes the weakness; review individual CVEs for product-specific impact.