Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/righettod/log4shell-payload-grabber
Tool to try to retrieve the java class used as dropper for the RCE in the context of log4shell vulnerability.
https://github.com/righettod/log4shell-payload-grabber
incident-response-tooling java-8 log4shell
Last synced: about 2 months ago
JSON representation
Tool to try to retrieve the java class used as dropper for the RCE in the context of log4shell vulnerability.
- Host: GitHub
- URL: https://github.com/righettod/log4shell-payload-grabber
- Owner: righettod
- License: gpl-3.0
- Archived: true
- Created: 2021-12-18T19:21:24.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2021-12-28T10:09:31.000Z (about 3 years ago)
- Last Synced: 2024-08-05T14:16:00.249Z (5 months ago)
- Topics: incident-response-tooling, java-8, log4shell
- Language: Java
- Homepage:
- Size: 11 MB
- Stars: 3
- Watchers: 4
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-log4shell - Tool
README
# Objective
[![Build package](https://github.com/righettod/log4shell-payload-grabber/actions/workflows/maven.yml/badge.svg?branch=main)](https://github.com/righettod/log4shell-payload-grabber/actions/workflows/maven.yml)
Tool to try to retrieve the java class used as dropper for the RCE.
The tool was tested again the following attacks kit:
* [JNDI-Exploit-Kit](https://github.com/pimps/JNDI-Exploit-Kit).
* [JNDIExploit](https://github.com/fengzhouc/JNDIExploit).
* [Rogue-JNDI](https://github.com/veracode-research/rogue-jndi).It is a [IntelliJ IDEA](https://www.jetbrains.com/idea/download) project.
# Requirements
[Java 8](https://adoptium.net/releases.html?variant=openjdk8) is required for compilation and execution because classes only present in this JDK are used for RMI information retieval.
Need Maven3+ for the building.
# Usage
```bash
$ java -jar get-payload.jar
[+] Missing LDAP/LDAPS/RMI URL or SER file!
URL: rmi://127.0.0.1:9997/gchero [--pause]
ldap://127.0.0.1:9998/gcherG
SER file: 899f0d32098d4f3b8d54ffa21fe9b0b6.ser
1) For RMI, if a second parameter, named '--pause', is specified then
the program wait the user press a key before to end the program allowing taking a heap dump
of the JVM process to capture the loaded remote object.
2) If a SER (serialized java object) file is passed then the program will load it
and wait the user press a key before to end the program allowing taking a heap dump like for RMI.
```![usage](usage.png)
Full demonstration in [this video](demo-full.mp4).
Use the following command to directly extract the download URL of the class when it is available:
```bash
$ java -jar get-payload.jar "ldap://127.0.0.1:1389/Basic/TomcatMemshell" | grep "Direct URL" | cut -d" " -f10
http://127.0.0.1:8080/com.feihong.ldap.template.TomcatMemshellTemplate.class
```For RMI, a second optional parameter named **--pause**, can be used to add a "virtual" break point allowing to perform a memory dump of the JVM tool process in order to capture loaded remote object:
![usage-rmi-01](usage-rmi-memory-dump01.png)
![usage-rmi-00](usage-rmi-memory-dump00.png)
Once created, the memory dump can be analyzed with different tools like for example [jhat](https://docs.oracle.com/javase/7/docs/technotes/tools/share/jhat.html):
![usage-rmi-00](usage-rmi-memory-dump02.png)
![usage-ser-00](usage-ser-file00.png)
# Compilation
Use the script named [package.sh](package.sh) and the binary jar file will be present in the **target** folder.
# Exploit class decompilation
The following tools can be used to achieve this task:
- GUI: http://java-decompiler.github.io/
- CMD: https://github.com/intoolswetrust/jd-cli