siunam's Website

My personal website

Home Writeups Research Blog Projects About

Stored XSS into onclick event with angle brackets and double quotes HTML-encoded and single quotes and backslash escaped | Jan 1, 2023

Introduction

Welcome to my another writeup! In this Portswigger Labs lab, you'll learn: Stored XSS into onclick event with angle brackets and double quotes HTML-encoded and single quotes and backslash escaped! Without further ado, let's dive in.

Background

This lab contains a stored cross-site scripting vulnerability in the comment functionality.

To solve this lab, submit a comment that calls the alert function when the comment author name is clicked.

Exploitation

Home page:

In here, we can view one of those posts:

And we can leave some comments.

Let's try to inject an XSS payload in the Website field:

As you can see, our input is inside the <a> tag's onclick event.

var tracker={track(){}};tracker.track('<our_input>');

Let's try to break out of that JavaScript code:

';+alert(document.domain)+';

So the result will be:

var tracker={track(){}};tracker.track('';+alert(document.domain)+';');

However, our ' is HTML encoded.

Let's try to escape that via \:

\';+alert(document.domain)+\';

Hmm… It escaped our \ too.

Now, when the browser has parsed out the HTML tags and attributes within a response, it will perform HTML-decoding of tag attribute values before they are processed any further. If the server-side application blocks or sanitizes certain characters that are needed for a successful XSS exploit, we can often bypass the input validation by HTML-encoding those characters.

Hence, our final payload will be:

&apos;+alert(document.domain)+&apos;

Note: The &apos; sequence is an HTML entity representing an apostrophe or single quote.

Nice!

What we've learned:

  1. Stored XSS into onclick event with angle brackets and double quotes HTML-encoded and single quotes and backslash escaped