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-2026-2905 Tenda HG9 Wireless Configuration Endpoint formWlanSetup stack-based overflow — HG9 8.8 High2026-02-22
CVE-2026-2886 Tenda A21 SetOnlineDevName set_device_name stack-based overflow — A21 8.8 High2026-02-21
CVE-2026-2885 D-Link DWR-M960 formIpv6Setup sub_469104 stack-based overflow — DWR-M960 8.8 High2026-02-21
CVE-2026-2884 D-Link DWR-M960 WAN Interface Setting formWanConfigSetup sub_41914C stack-based overflow — DWR-M960 8.8 High2026-02-21
CVE-2026-2883 D-Link DWR-M960 formIpQoS sub_427D74 stack-based overflow — DWR-M960 8.8 High2026-02-21
CVE-2026-2882 D-Link DWR-M960 formDosCfg sub_46385C stack-based overflow — DWR-M960 8.8 High2026-02-21
CVE-2026-2881 D-Link DWR-M960 Advanced Firewall Configuration Endpoint formFirewallAdv sub_425FF8 stack-based overflow — DWR-M960 8.8 High2026-02-21
CVE-2026-2877 Tenda A18 Httpd Service WifiExtraSet strcpy stack-based overflow — A18 8.8 High2026-02-21
CVE-2026-2876 Tenda A18 setBlackRule parse_macfilter_rule stack-based overflow — A18 8.8 High2026-02-21
CVE-2026-2874 Tenda A21 fast_setting_wifi_set form_fast_setting_wifi_set stack-based overflow — A21 8.8 High2026-02-21
CVE-2026-2873 Tenda A21 openSchedWifi setSchedWifi stack-based overflow — A21 8.8 High2026-02-21
CVE-2026-2872 Tenda A21 MAC Filtering Configuration Endpoint setBlackRule set_device_name stack-based overflow — A21 8.8 High2026-02-21
CVE-2026-2871 Tenda A21 SetIpMacBind fromSetIpMacBind stack-based overflow — A21 8.8 High2026-02-21
CVE-2026-2870 Tenda A21 formSetQosBand set_qosMib_list stack-based overflow — A21 8.8 High2026-02-21
CVE-2019-25437 Foscam Video Management System 1.1.6.6 Buffer Overflow Denial of Service — Foscam Video Management System 6.2 Medium2026-02-20
CVE-2019-25435 Sricam DeviceViewer 3.12.0.1 Local Buffer Overflow DEP Bypass — Sricam DeviceViewer 7.8 High2026-02-20
CVE-2019-25434 SpotAuditor 5.3.1.0 Denial of Service via Registration Name Field — Nsauditor SpotAuditor 7.5 High2026-02-20
CVE-2026-2857 D-Link DWR-M960 Port Forwarding Configuration Endpoint formPortFw sub_423E00 stack-based overflow — DWR-M960 8.8 High2026-02-20
CVE-2026-2856 D-Link DWR-M960 Filter Configuration Endpoint formFilter sub_424AFC stack-based overflow — DWR-M960 8.8 High2026-02-20
CVE-2026-2855 D-Link DWR-M960 DDNS Settings formDdns sub_4648F0 stack-based overflow — DWR-M960 8.8 High2026-02-20
CVE-2026-2854 D-Link DWR-M960 NTP Configuration Endpoint formNtp sub_4611CC stack-based overflow — DWR-M960 8.8 High2026-02-20
CVE-2026-2853 D-Link DWR-M960 System Log Configuration Endpoint formSysLog sub_462E14 stack-based overflow — DWR-M960 8.8 High2026-02-20
CVE-2019-25365 ChaosPro 2.0 - Buffer Overflow — ChaosPro 9.8 Critical2026-02-18
CVE-2019-25364 Win10 MailCarrier 2.51 - 'POP3 User' Remote Buffer Overflow — Win10 MailCarrier 9.8 Critical2026-02-18
CVE-2019-25363 WMV to AVI MPEG DVD WMV Convertor 4.6.1217 - Denial of Service — WMV to AVI MPEG DVD WMV Convertor 7.5 High2026-02-18
CVE-2019-25361 Ayukov NFTP client 1.71 - 'SYST' Buffer Overflow — Ayukov NFTP client 9.8 Critical2026-02-18
CVE-2019-25360 Aida64 6.10.5200 - Buffer Overflow — Aida64 9.8 Critical2026-02-18
CVE-2019-25357 Control Center PRO 6.2.9 - Local Stack Based BufferOverflow — Control Center PRO 8.4 High2026-02-18
CVE-2026-2657 wren-lang wren Error Message wren_compiler.c printError stack-based overflow — wren 3.3 Low2026-02-18
CVE-2026-2329 Grandstream GXP1600 VoIP Phones - Unauthenticated stack buffer overflow — GXP1610 9.8 -2026-02-18

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