 
                            In Java SE 6 and later, privileged code must either uses use the AccessController mechanism or needs to be signed by the an owner (or provider) whom a user of the code can trust. An adversary is capable of linking the user trusts. Attackers could link privileged code with malicious code if some the privileged code directly or indirectly uses invokes code present within another package. This from another package. Trusted JAR files often contain code that requires no elevated privileges itself but that depends on privileged code; such code is known as security-sensitive code. If an attacker can link security-sensitive code with malicious code, he or she can indirectly cause incorrect behavior. This exploit is called a mix-and-match attack. A mix and match attack is not possible if the code is signed because by default, the jarsigner tool signs the finished manifest that contains the names of the included classes along with their digests.
Normally, execution of untrusted code causes loss of privileges; the Java security model rescinds privileges when a trusted method invokes an untrusted one. When trusted code calls Privileges are lost as soon as untrusted code is executed. If trusted code calls some untrusted code that attempts to perform some action requiring permissions not granted withheld by the security policy, the action is not allowedJava security model disallows that action. However, privileged code may use a class that exists in an untrusted container and performs only unprivileged operations. If the attacker replaces this class were to replace the class in the untrusted container with a malicious implementationclass, the trusted code will retrieve might receive incorrect results .and misbehave at the discretion of the malicious code.
According to the Java SE Documentation, "Extension Mechanism Architecture" [EMA 2014]:Wiki Markup 
A package sealed within a JAR specifies that all classes defined in that package must originate from the same JAR. Otherwise, a
SecurityExceptionis thrown.
Sealing a JAR file automatically enforces the requirement of keeping privileged code together. In addition, it is important to adhere to guideline SEC01-J. Minimize minimize the accessibility of classes and their members.
Noncompliant Code Example (Privileged Code)
This noncompliant code example uses includes a doPrivileged() block and calls a method defined in a class that exists in a different, untrusted package. JAR file:
| Code Block | ||
|---|---|---|
| 
 | ||
| package trusted; import untrusted.RetValue; public class MixMatch { private void privilegedMethod() throws IOException { FileInputStream fis; try { fis = (FileInputStream) AccessController.doPrivileged( new PrivilegedExceptionActionPrivilegedExceptionAction<Void>() { public FileInputStreamVoid run() throws IOException, FileNotFoundException { final FileInputStream returnfis = new FileInputStream("file.txt"); } try { } RetValue rt = new RetValue(); RetValue rt = new RetValue(); if if(rt.getValue() == 1) { // doDo something with sensitive file } } catch (PrivilegedActionException e) { finally { fis.close(); } return null; // forwardNothing to handler and log return } } finally { ); } catch fis.close();PrivilegedActionException e) { // Forward to handler and log } } public static void main(String[] args) throws IOException { MixMatch mm = new MixMatch(); mm.privilegedMethod(); } } // In another JAR file: package untrusted; class RetValue { public int getValue() { return 1; } } | 
An attacker can provide an implementation of class RetValue so that the privileged code uses the wrong an incorrect return value. If Even though class MixMatch consists only of trusted only , signed code, even then an attacker can still cause this behavior by maliciously deploying a legibly signed class in the class path of the privileged codevalid signed JAR file containing the untrusted RetValue class.
This example almost violates SEC01-J. Do not allow tainted variables in privileged blocks but does not do so. It instead allows potentially tainted code in its doPrivileged() block, which is a similar issue.
Noncompliant Code Example (Security-Sensitive Code)
This noncompliant code example improves on the previous example by moving the use of the RetValue class outside the doPrivileged() block:
| Code Block | ||
|---|---|---|
| 
 | ||
| package trusted;
import untrusted.RetValue;
public class MixMatch {
  private void privilegedMethod() throws IOException {
    try {
      final FileInputStream fis = AccessController.doPrivileged(
        new PrivilegedExceptionAction<FileInputStream>() {
          public FileInputStream run() throws FileNotFoundException {
            return new FileInputStream("file.txt");
          }
        }
      );
      try {
        RetValue rt = new RetValue();
        if (rt.getValue() == 1) {
          // Do something with sensitive file
        }
      } finally {
        fis.close();
      }
    } catch (PrivilegedActionException e) {
      // Forward to handler and log
    }
  }
  public static void main(String[] args) throws IOException {
    MixMatch mm = new MixMatch();
    mm.privilegedMethod();
  }
}
// In another JAR file:
package untrusted;
class RetValue {
  public int getValue() {
    return 1;
  }
}
 | 
Although the RetValue class is used only outside the doPrivileged() block, the behavior of RetValue.getValue() affects the behavior of security-sensitive code that operates on the file opened within the doPrivileged() block. Consequently, an attacker can still exploit the security-sensitive code with a malicious implementation of RetValue.
Compliant Solution
This compliant solution combines all privileged security-sensitive code into the same package and the same JAR file. It also reduces the accessibility of the getValue() method to package-private. Sealing the package is necessary to prevent attackers from inserting any rogue classes.
| Code Block | ||
|---|---|---|
| 
 | ||
| package trusted; public class MixMatch { // ... } // In the same signed & sealed JAR file: package trusted; class RetValue { int getValue() { return 1; } } | 
To seal a package, use the sealed attribute in the JAR file's manifest file header. This is shown below., as follows:
| Code Block | 
|---|
| Name: trusted/ // packagePackage name Sealed: true // sealed attribute Sealed attribute | 
Exception
ENV01-J-EX0: Independent groups of privileged code and associated security-sensitive code (a "group" hereafter) may be placed in separate sealed packages and even in separate JAR files, subject to the following enabling conditions:
- The code in any one of these independent groups must lack any dynamic or static dependency on any of the code in any of the other groups. This means that code from one such group cannot invoke code from any of the others, whether directly or transitively.
- All code from any single group is contained within one or more sealed packages.
- All code from any single group is contained within a single signed JAR file.
Risk Assessment
Failure to place all privileged code together , in one package and sealing seal the package can lead to mix-and-match attacks.
| Rule | Severity | Likelihood | Detectable | 
|---|
| Repairable | Priority | Level | 
|---|---|---|
| ENV01-J | High | 
| Probable | 
| No | 
| No | 
| P6 | 
| L2 | 
Automated Detection
TODO
Related Vulnerabilities
Search for vulnerabilities resulting from the violation of this rule on the CERT website.
References
| Wiki Markup | 
|---|
| \[[API 2006|AA. Java References#API 06]\]
\[[Ware 2008|AA. Java References#Ware 08]\]
\[[McGraw 2000|AA. Java References#Ware 00]\] Rule 7: If You Must Sign Your Code, Put It All in One Archive File (sic)
\[[MITRE 2009|AA. Java References#MITRE 09]\] [CWE-349: Acceptance of Extraneous Untrusted Data With Trusted Data|http://cwe.mitre.org/data/definitions/349.html] | 
Detecting code that should be considered privileged or sensitive requires programmer assistance. Given identified privileged code as a starting point, automated tools could compute the closure of all code that can be invoked from that point. Such a tool could plausibly determine whether all code in that closure exists within a single package. A further check of whether the package is sealed is feasible.
| Tool | Version | Checker | Description | ||||||
|---|---|---|---|---|---|---|---|---|---|
| CodeSonar | 
 | JAVA.INSEC.LDAP.DA | LDAP authentication disabled (Java) | 
Android Implementation Details
java.security.AccessController exists on Android for compatibility purposes only, and it should not be used.
Related Guidelines
Bibliography
| [EMA 2014] | Extension Mechanism Architecture, "Optional Package Sealing" | 
| Rule 7, If you must sign your code, put it all in one archive file | |
...
01. Runtime Environment (ENV) ENV02-J. Create a secure sandbox using a Security Manager