Spring4Shell Detection Script

Scanner to detect the Spring4Shell vulnerability on input URLs

Note: Detection Script has been tested on applications deployed using Apache Tomcat Server

Prerequisite's

  • python3
  • python3 -m pip install -r requirements.txt

Usage

python3 detect.py --help

usage: detect.py [-h] [--file FILE] --url URL [--debug] [--get] [--post] [--ver]

options:
  -h, --help   show this help message and exit
  --file FILE  File containing Form Endpoints
  --url URL    target Form Endpoints
  --debug      Print errors
  --get        Use Get Method
  --post       Use Post Method
  --ver        Perform Version Detection

Example: 1

Run the script for single URL to detect Spring4Shell Vulnerability

python3 detect.py --url http://192.168.0.1/greeting

Example: 2

Run the script for Multiple URLs by providing text file with ips to detect Spring4Shell Vulnerability

python3 detect.py --file ips.txt

Example: 3

Run the script for single URL to detect Spring4Shell Vulnerability along with version detection

python3 detect.py --url http://192.168.0.1/greeting --ver

Example: 4

Run the script for single URL to detect Spring4Shell Vulnerability, mentioning the type of request

python3 detect.py --url http://192.168.0.1/greeting --get

Sample Testing

We have a Sample Spring Application set up -

Running the script against it -

python3 detect.py --url http://192.168.0.1/greeting

Output -

Running via proxy to confirm -

References

https://www.rapid7.com/blog/post/2022/03/30/spring4shell-zero-day-vulnerability-in-spring-framework/

https://github.com/TheGejr/SpringShell/blob/master/exp.py

https://twitter.com/RandoriAttack/status/1509298490106593283

Created By

Arjun Anand V, Security Analyst

Abhishek Ganesan, Security Analyst

Ridhwan Roshan, Security Analyst

Cyber Security Works