6.0 KiB
aegis4j
Avoid the NEXT Log4Shell vulnerability!
The Java platform has accrued a number of features over the years. Some of these features are no longer commonly used, but their existence remains a security liability, providing attackers with a diverse toolkit to leverage against Java-based systems.
It is possible to eliminate some of this attack surface area by creating custom JVM images with jlink, but this is not always feasible or desired. Another option is to use the --limit-modules command line parameter when running your application, but this is a relatively coarse tool that cannot be used to disable individual features like serialization or native process execution.
A third option is aegis4j, a Java agent which can patch key system classes to completely disable a number of standard Java features:
jndi
: all JNDI functionality (javax.naming.*
)rmi
: all RMI functionality (java.rmi.*
)process
: all process execution functionality (Runtime.exec()
,ProcessBuilder
)httpserver
: all use of the JDK HTTP server (com.sun.net.httpserver.*
)serialization
: all Java serialization (ObjectInputStream
,ObjectOutputStream
)unsafe
: all use ofsun.misc.Unsafe
scripting
: all JSR 223 scripting (javax.script.*
)jshell
: all use of the Java Shell API (jdk.jshell.*
)
Download
The aegis4j JAR is available in the Maven Central repository.
Usage: Attach at Application Startup
To attach at application startup, blocking all features listed above, add the agent to your java command line:
java -cp <classpath> -javaagent:aegis4j-1.1.jar <main-class> <arguments>
Or, if you want to configure the specific features to block:
java -cp <classpath> -javaagent:aegis4j-1.1.jar=block=<features> <main-class> <arguments>
Or, if you want to use the default block list, but unblock specific features:
java -cp <classpath> -javaagent:aegis4j-1.1.jar=unblock=<features> <main-class> <arguments>
Feature lists should be comma-delimited (e.g. jndi,rmi,unsafe
).
Usage: Attach to a Running Application
To attach to a running application, blocking all features listed above, run the following command:
java -jar aegis4j-1.1.jar <application-pid>
Or, if you want to configure the specific features to block:
java -jar aegis4j-1.1.jar <application-pid> block=<features>
Or, if you want to use the default block list, but unblock specific features:
java -jar aegis4j-1.1.jar <application-pid> unblock=<features>
Feature lists should be comma-delimited (e.g. jndi,rmi,unsafe
).
The application process ID, or PID, can usually be determined by running the jps
command.
Compatibility
The aegis4j Java agent is compatible with JDK 11 and newer.
Monitoring
The list of Java features blocked by aegis4j is available via the aegis4j.blocked.features
system property, which
can be queried at runtime via Java code, JMX, APM agents, etc.
When an attempt is made to use a blocked feature, the type of exception thrown varies according to context, but the exception
message always uses the format "<action> blocked by aegis4j"
.
Building
To build aegis4j, run gradlew build
.
Digging Deeper
Class modifications are performed using Javassist. The specific class modifications performed are configured in the mods.properties file.
Some of the tests validate the agent against actual vulnerabilities (e.g.
CVE-2015-7501,
CVE-2019-17531,
CVE-2021-44228).
The tests are run with the jdk.attach.allowAttachSelf=true
system property, so that the agent can be attached and tested
locally. Tests are also run in individual VM instances, so that the class modifications performed in one test do not affect other
tests.
Ideally aegis4j could block all reflection as well, since it's often used in exploit chains. However, reflection is used everywhere, including the JDK lambda internals, Spring Boot, JUnit, and many other libraries and frameworks. The best way to mitigate the dangers of reflection is to upgrade to JDK 17 or later, where many of the internal platform classes have been made inaccessible via reflection (see JEP 403, or the full list of packages that were locked down between JDK 8 and JDK 17).
Related Work
log4j-jndi-be-gone: A Java agent which patches the Log4Shell vulnerability (CVE-2021-44228).
Log4jHotPatch: A similar Java agent from the Amazon Corretto team.
Logout4Shell: Vaccine exploit which leverages the Log4Shell vulnerability to patch the Log4Shell vulnerability.
Logpresso log4j2-scan: Command line tool for scanning (and patching) JAR files for Log4Shell vulnerabilities.
ysoserial: A proof-of-concept tool for generating Java serialization vulnerability payloads.
NotSoSerial: A Java agent which attempts to mitigate serialization vulnerabilities by selectively blocking serialization attempts.
An In-Depth Study of More Than Ten Years of Java Exploitation: Study of real-world Java exploits between 2003 and 2013 (citations).
A Systematic Analysis and Hardening of the Java Security Architecture: PhD thesis which incorporates the above research and proposes specific hardening measures.