Siunam's Website

My personal website

Home About Blog Writeups Projects E-Portfolio

Information disclosure in error messages | Dec 16, 2022

Introduction

Welcome to my another writeup! In this Portswigger Labs lab, you’ll learn: Information disclosure in error messages! Without further ado, let’s dive in.

Background

This lab’s verbose error messages reveal that it is using a vulnerable version of a third-party framework. To solve the lab, obtain and submit the version number of this framework.

Exploitation

Home page:

In here, we can view the details of each products.

Let’s click on the View details button:

In here, we can see there is a GET parameter called productId.

Hmm… What if that parameter is doing a SQL query?

If so, we can try to trigger a SQL error via ':

Boom! We found it!

In searchsploit(An offline version of Exploit-DB), we can see that it’s vulnerable to Remote Code Execution(RCE)!

┌──(root🌸siunam)-[~/ctf/Portswigger-Labs/Information-Disclosure/ID-1]
└─# searchsploit Apache Struts 2 2.3.31
-------------------------------------------------------------------------------------------------------- ---------------------------------
 Exploit Title                                                                                          |  Path
-------------------------------------------------------------------------------------------------------- ---------------------------------
Apache Struts 2.0.1 < 2.3.33 / 2.5 < 2.5.10 - Arbitrary Code Execution                                  | multiple/remote/44556.py
Apache Struts 2.3 < 2.3.34 / 2.5 < 2.5.16 - Remote Code Execution (1)                                   | linux/remote/45260.py
Apache Struts 2.3 < 2.3.34 / 2.5 < 2.5.16 - Remote Code Execution (2)                                   | multiple/remote/45262.py
Apache Struts 2.3.5 < 2.3.31 / 2.5 < 2.5.10 - 'Jakarta' Multipart Parser OGNL Injection (Metasploit)    | multiple/remote/41614.rb
Apache Struts 2.3.5 < 2.3.31 / 2.5 < 2.5.10 - Remote Code Execution                                     | linux/webapps/41570.py
-------------------------------------------------------------------------------------------------------- ---------------------------------

What we’ve learned:

  1. Information disclosure in error messages