 
                            ...
In fact, relying on environment variables is more than a simple portability issue. An attacker can essentially control all environment variables that enter a program, using a mechanism such as the java.lang.ProcessBuilder class.
Consequently, if when an environment variable contains information that is available by other means, including system properties, that environment variable must not be used.
...
This compliant solution obtains the user name using the user.name system property. This property always contains the correct user name, even if when the USER environment variable has been set to an incorrect value, or does not existis missing.
| Code Block | ||
|---|---|---|
| 
 | ||
| 
String username = System.getProperty("user.name");
 | 
...
| <ac:structured-macro ac:name="unmigrated-wiki-markup" ac:schema-version="1" ac:macro-id="fed52057af7db073-675119bb-48bd4a82-ac1c9351-5794dcda44663a18c22024da"><ac:plain-text-body><![CDATA[ | [[API 2006 | AA. Bibliography#API 06]] | ]]></ac:plain-text-body></ac:structured-macro> | |
| <ac:structured-macro ac:name="unmigrated-wiki-markup" ac:schema-version="1" ac:macro-id="d506b9cf7f3c58b9-e06ae165-4c4048de-88cc9ff3-d32a83fa6898271cf8c12759"><ac:plain-text-body><![CDATA[ | [[Campione 1996 | AA. Bibliography#Campione 96]] | 
 | ]]></ac:plain-text-body></ac:structured-macro> | 
...