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

Goal: 1000 CNY · Raised: 1000 CNY

100.0%

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

2518 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-2020-15417 NETGEAR R6700 缓冲区错误漏洞 — R6700 8.8 -2020-07-28
CVE-2020-10924 NETGEAR R6700 缓冲区错误漏洞 — R6700 8.0 -2020-07-28
CVE-2020-14511 Moxa EDR-G902和EDR-G903 缓冲区错误漏洞 — EDR-G902 and EDR-G903 Series Routers 9.8 -2020-07-15
CVE-2020-12497 Phoenix Contact Automation Worx <= 1.87: stack-based overflow — Automation Worx 7.8 High2020-07-01
CVE-2020-12498 Phoenix Contact Automation Worx <= 1.87: out-of-bounds read remote code execution — Automation Worx 7.8 High2020-07-01
CVE-2020-4044 Local users can perform a buffer overflow attack against the xrdp-sesman service and then impersonate it — xrdp 7.5 High2020-06-30
CVE-2020-12019 Advantech WebAccess Node 缓冲区错误漏洞 — WebAccess Node 9.8 -2020-06-15
CVE-2020-2027 PAN-OS: Buffer overflow in authd authentication response — PAN-OS 7.2 High2020-06-10
CVE-2020-2006 PAN-OS: Buffer overflow in management server payload parser — PAN-OS 7.2 High2020-05-13
CVE-2020-12002 Advantech WebAccess Node 缓冲区错误漏洞 — Advantech WebAccess Node 9.8 -2020-05-08
CVE-2019-5621 ABBS Software Audio Media Player Stack-based Buffer Overflow — Audio Media Player 7.8 -2020-04-29
CVE-2019-5618 A-PDF WAV to MP3 Stack-based Buffer Overflow — WAV to MP3 7.8 -2020-04-29
CVE-2019-5619 AASync.com AASync Stack-based Buffer Overflow — AASync 9.8 -2020-04-29
CVE-2020-6996 Triangle MicroWorks DNP3 Outstation Libraries 缓冲区错误漏洞 — Triangle MicroWorks DNP3 Outstation LibrariesDNP3 Outstation .NET Protocol components and DNP3 Outstation ANSI C source code libraries are affected:3.16.00 through 3.25.01 9.8 -2020-04-15
CVE-2020-10615 Triangle MicroWorks SCADA Data Gateway 缓冲区错误漏洞 — Triangle MicroWorks SCADA Data Gateway 3.02.0697 through 4.0.122, 2.41.0213 through 4.0.122 7.5 -2020-04-15
CVE-2020-10639 Eaton HMiSoft VU3 缓冲区错误漏洞 — Eaton HMiSoft VU3 (HMIVU3 runtime not impacted) 7.8 -2020-04-15
CVE-2020-1990 PAN-OS: Buffer overflow in the management server — PAN-OS 7.2 High2020-04-08
CVE-2020-5735 Amcrest IPM-721S 缓冲区错误漏洞 — Amcrest 8.8 -2020-04-08
CVE-2020-10599 VISAM VBASE Editor和VBASE Web-Remote Module 缓冲区错误漏洞 — VBASE Editor 9.8 -2020-04-03
CVE-2020-7065 mb_strtolower (UTF-32LE): stack-buffer-overflow at php_unicode_tolower_full — PHP 7.4 High2020-04-01
CVE-2020-5344 Dell EMC iDRAC7、iDRAC8和iDRAC9 缓冲区错误漏洞 — Integrated Dell Remote Access Controller (iDRAC) 7.0 High2020-03-31
CVE-2020-10607 Advantech WebAccess 缓冲区错误漏洞 — Advantech WebAccess 9.8 -2020-03-27
CVE-2020-10881 TP-Link Archer A7 AC1750 缓冲区错误漏洞 — Archer A7 9.8 -2020-03-25
CVE-2020-7007 Moxa EDS-G516E和EDS-510E 缓冲区错误漏洞 — Moxa EDS-G516E Series firmware, Version 5.2 or lower 9.8 -2020-03-24
CVE-2020-6989 Moxa PT-7528和PT-7828 缓冲区错误漏洞 — Moxa PT-7528 series firmware, Version 4.0 or lower, PT-7828 series firmware, Version 3.9 or lower 9.8 -2020-03-24
CVE-2020-7002 Delta Electronics Delta Industrial Automation CNCSoft 缓冲区错误漏洞 — Delta Industrial Automation CNCSoft ScreenEditor 7.8 -2020-03-18
CVE-2019-5153 Moxa AWK-3131A 缓冲区错误漏洞 — Moxa 8.8 -2020-02-25
CVE-2020-8860 Samsung Galaxy 10 缓冲区错误漏洞 — Galaxy S10 8.0 -2020-02-22
CVE-2020-5234 Untrusted data can lead to DoS attack in MessagePack for C# and Unity — MessagePack 4.8 Medium2020-01-31
CVE-2019-17094 Stack-Based Overflow vulnerability in Belkin WeMo Insights Switch — Belkin WeMo Insight Switch 8.3 High2020-01-27

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