siunam's Website

My personal website

Home Writeups Research Blog Projects About

CL.0 request smuggling | Feb 15, 2023

Introduction

Welcome to my another writeup! In this Portswigger Labs lab, you'll learn: CL.0 request smuggling! Without further ado, let's dive in.

Background

This lab is vulnerable to CL.0 request smuggling attacks. The back-end server ignores the Content-Length header on requests to some endpoints.

To solve the lab, identify a vulnerable endpoint, smuggle a request to the back-end to access to the admin panel at /admin, then delete the user carlos.

This lab is based on real-world vulnerabilities discovered by PortSwigger Research. For more details, check out Browser-Powered Desync Attacks: A New Frontier in HTTP Request Smuggling.

Exploitation

Home page:

In the home page, we see there is a "Admin panel":

However, it's blocked.

Maybe we can bypass that via HTTP request smuggling?

In /, we can try to test CL.0 HTTP request smuggling.

Request smuggling vulnerabilities are the result of discrepancies in how chained systems determine where each request starts and ends. This is typically due to inconsistent header parsing, leading to one server using a request's Content-Length and the other treating the message as chunked. However, it's possible to perform many of the same attacks without relying on either of these issues.

In some instances, servers can be persuaded to ignore the Content-Length header, meaning they assume that each request finishes at the end of the headers. This is effectively the same as treating the Content-Length as 0.

If the back-end server exhibits this behavior, but the front-end still uses the Content-Length header to determine where the request ends, we can potentially exploit this discrepancy for HTTP request smuggling. This vulnerability is called "CL.0".

To probe for CL.0 vulnerabilities, first send a request containing another partial request in its body, then send a normal follow-up request. We can then check to see whether the response to the follow-up request was affected by the smuggled prefix.

Armed with above information, we can use Burp Suite's Repeater to test it.

From the HTTP history, send the GET / request to Burp Repeater twice:

Then, in the attack request, change the method to POST:

After that, add the smuggle data in the body:

POST / HTTP/1.1
Host: 0ad000d80492cc59c16181d20040007a.web-security-academy.net
Content-Type: application/x-www-form-urlencoded
Content-Length: 0

GET /404pls HTTP/1.1
X-Foo: x

If the server responds to the second request as normal, this endpoint is not vulnerable.

If the response to the second request matches what you expected from the smuggled prefix, like 404 response, the back-end server is ignoring the Content-Length of requests. Which means it's vulnerable to CL.0 HTTP request smuggling.

After some testing, I found that stuff that are in /resources/ are vulnerable to CL.0 HTTP request smuggling:

Attack request:

Normal request:

Nice!

Now, we can try to bypass the access control in /admin by modifiying the smuggled path:

Finally, send the requests in group:

Normal request:

Oh! No more 404 response!

Then scroll down:

Nice! We successfully bypassed the access control in /admin!

Let's delete user carlos!

Attack request:

Normal request:

What we've learned:

  1. CL.0 request smuggling