siunam's Website

My personal website

Home Writeups Blog Projects About E-Portfolio

Basic server-side template injection | Dec 23, 2022

Introduction

Welcome to my another writeup! In this Portswigger Labs lab, you’ll learn: Basic server-side template injection! Without further ado, let’s dive in.

Background

This lab is vulnerable to server-side template injection due to the unsafe construction of an ERB template.

To solve the lab, review the ERB documentation to find out how to execute arbitrary code, then delete the morale.txt file from Carlos’s home directory.

Exploitation

Home page:

First, we need to detect does the SSTI(Server-Side Template Injection) vulnerability exist.

To do so, we can fuzz the site via $\{\{<\%[\%'"\}\}\%\\, which might trigger an template error.

In the home page, I notice something interesting:

When I try to view the details in the first, it displays Unfortunately this product is out of stock.

Let’s check the HTTP history via Burp Suite:

When a product is out of stock, the application will render a template, which is using the message parameter.

Let’s fuzz this parameter:

Hmm… Let’s try to do some maths:

{{7*7}}

${7*7}

Nope.

After some trial and error, I found this is working:

<%= 7*7 %>
<%= foobar %>

Note: The payload is URL encoded.

According to HackTricks, this template engine is ERB, which is written in Ruby.

Let’s dig deeper in ERB’s documentation!

In this blog, we can execute OS command via system method:

Let’s try that:

<%= system("ls") %>

We successfully executed an OS command!

Let’s delete that morale.txt file:

<%= system("rm morale.txt") %>

We did it!

What we’ve learned:

  1. Basic server-side template injection