Description
The product is composed of a server that relies on the client to implement a mechanism that is intended to protect the server.
When the server relies on protection mechanisms placed on the client side, an attacker can modify the client-side behavior to bypass the protection mechanisms, resulting in potentially unexpected interactions between the client and server. The consequences will vary, depending on what the mechanisms are trying to protect.
Potential Impact
Access Control, Availability
Bypass Protection Mechanism, DoS: Crash, Exit, or Restart
Access Control
Bypass Protection Mechanism, Gain Privileges or Assume Identity
Demonstrative Examples
$server = "server.example.com";$username = AskForUserName();$password = AskForPassword();$address = AskForAddress();$sock = OpenSocket($server, 1234);writeSocket($sock, "AUTH $username $password\n");$resp = readSocket($sock);if ($resp eq "success") {
# username/pass is valid, go ahead and update the info!
writeSocket($sock, "CHANGE-ADDRESS $username $address\n";
}else {print "ERROR: Invalid Authentication!\n";}$sock = acceptSocket(1234);($cmd, $args) = ParseClientRequest($sock);if ($cmd eq "AUTH") {
($username, $pass) = split(/\s+/, $args, 2);$result = AuthenticateUser($username, $pass);writeSocket($sock, "$result\n");
# does not close the socket on failure; assumes the
# user will try again
}elsif ($cmd eq "CHANGE-ADDRESS") {if (validateAddress($args)) {$res = UpdateDatabaseRecord($username, "address", $args);writeSocket($sock, "SUCCESS\n");}else {writeSocket($sock, "FAILURE -- address is malformed\n");}}Mitigations & Prevention
For any security checks that are performed on the client side, ensure that these checks are duplicated on the server side. Attackers can bypass the client-side checks by modifying values after the checks have been performed, or by changing the client to remove the client-side checks entirely. Then, these modified values would be submitted to the server. Even though client-side checks provide minimal benefits with respect to server-side security, they are still useful. First,
If some degree of trust is required between the two entities, then use integrity checking and strong authentication to ensure that the inputs are coming from a trusted source. Design the product so that this trust is managed in a centralized fashion, especially if there are complex or numerous communication channels, in order to reduce the risks that the implementer will mistakenly omit a check in a single code path.
Detection Methods
- Fuzzing — Use dynamic tools and techniques that interact with the software using large test suites with many diverse inputs, such as fuzz testing (fuzzing), robustness testing, and fault injection. The software's operation may slow down, but it should not become unstable, crash,
- Manual Analysis — Use tools and techniques that require manual (human) analysis, such as penetration testing, threat modeling, and interactive tools that allow the tester to record and modify an active session. These may be more effective than strictly automated techniques. This is especially the case with weaknesses
Real-World CVE Examples
| CVE ID | Description |
|---|---|
| CVE-2024-50653 | Chain: e-commerce product has a "front-end restriction" for coupon use (CWE-602), but the server does not restrict the number of requests for the same coupon (CWE-799) |
| CVE-2022-33139 | SCADA system only uses client-side authentication, allowing adversaries to impersonate other users. |
| CVE-2006-6994 | ASP program allows upload of .asp files by bypassing client-side checks. |
| CVE-2007-0163 | steganography products embed password information in the carrier file, which can be extracted from a modified client. |
| CVE-2007-0164 | steganography products embed password information in the carrier file, which can be extracted from a modified client. |
| CVE-2007-0100 | client allows server to modify client's configuration and overwrite arbitrary files. |
Related Weaknesses
Taxonomy Mappings
- OWASP Top Ten 2004: A1 — Unvalidated Input
Frequently Asked Questions
What is CWE-602?
CWE-602 (Client-Side Enforcement of Server-Side Security) is a software weakness identified by MITRE's Common Weakness Enumeration. It is classified as a Class-level weakness. The product is composed of a server that relies on the client to implement a mechanism that is intended to protect the server.
How can CWE-602 be exploited?
Attackers can exploit CWE-602 (Client-Side Enforcement of Server-Side Security) to bypass protection mechanism, dos: crash, exit, or restart. This weakness is typically introduced during the Architecture and Design, Architecture and Design phase of software development.
How do I prevent CWE-602?
Key mitigations include: For any security checks that are performed on the client side, ensure that these checks are duplicated on the server side. Attackers can bypass the client-side checks by modifying values after the che
What is the severity of CWE-602?
CWE-602 is classified as a Class-level weakness (High abstraction). It has been observed in 6 real-world CVEs.