Uninitialized variable vulnerability

- Problem with boolean variables that are forcibly initialized to false by the Java compiler

Sites such as CWE and VULNCAT all describe only code quality and memory problems, so I made an example code for the vulnerability of an uninitialized variable(1). In the Java language, boolean member variables that are not explicitly initialized are forcibly initialized to false by the compiler(2). This can lead to logic vulnerabilities(3). If Java had a type like Python's NoneType(4), this might not have happened.

This is a java code example of the merchant server that needs to complete the payment(finalizeOrder Method) after receiving the card payment information(orderPgData instance) from the payment gateway (ex. paypal). Merchant server performs amount validation (OrderPgData.validateAmount()) for paypal payment and does not perform amount validation for card payment. In the case of card payment, amount validation is not performed, but isPaymentAmountTampered variable is initialized to false by the java compiler, and the payment that a hacker modifies the price(The hacker tampered with paymentAmount from 100 to 10.) is completed without any problem by the merchant server.

You might wonder if this will happen, but lazy developers code minimally to only make it work. The rest of the additional features are not coded and are often stated as "future development" in the comments.

The CVE-2019-15900 vulnerability is the most similar to the vulnerability set in this document. However, in the CVE-2019-15900 vulnerability, a specific memory area value is fixed to a specific value, and a problem occurs by using it. In addition, in modern OS, "ASLR (Address Space Layout Randomization)" is applied, so this vulnerability cannot be used as an actual attack(5).

You can try running the code online: https://paiza.io/projects/e/W29UBDANL72yP7KFmB9-Vw?theme=twilight

Related documentation: (1) https://cwe.mitre.org/data/definitions/457.html, https://cwe.mitre.org/data/definitions/456.html, https://vulncat.fortify.com/en/detail?id=desc.controlflow.cpp.uninitialized_variable#C%2FC%2B%2B (2) https://docs.oracle.com/javase/specs/jls/se7/html/jls-4.html#jls-4.12.5 (3) https://cwe.mitre.org/data/definitions/840.html (4) https://docs.python.org/3.7/library/constants.html (5) https://paiza.io/projects/e/W29UBDANL72yP7KFmB9-Vw?theme=twilight