Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                

A7 - Cross - Site Scripting (XSS) : © 2020 Nexusguard Limited - Confidential & Proprietary

Download as pdf or txt
Download as pdf or txt
You are on page 1of 5

A7 – CROSS – SITE

SCRIPTING (XSS)

© 2020 Nexusguard Limited – Confidential & Proprietary


A7 – Cross-Site Scripting
There are three forms of XSS, usually targeting users' browsers:

• Reflected XSS: The application or API includes unvalidated and unescaped user input as part of
HTML output. A successful attack can allow the attacker to execute arbitrary HTML and JavaScript in
the victim’s browser. Typically the user will need to interact with some malicious link that points to an
attacker-controlled page, such as malicious watering hole websites, advertisements, or similar.
• Stored XSS: The application or API stores unsanitized user input that is viewed at a later time by
another user or an administrator. Stored XSS is often considered a high or critical risk.
• DOM XSS: JavaScript frameworks, single-page applications, and APIs that dynamically include
attacker-controllable data to a page are vulnerable to DOM XSS. Ideally, the application would not
send attacker-controllable data to unsafe JavaScript APIs.

Typical XSS attacks include session stealing, account takeover, MFA bypass, DOM node replacement or
defacement (such as trojan login panels), attacks against the user's browser such as malicious software
downloads, key logging, and other client-side attacks.

© 2020 Nexusguard Limited – Confidential & Proprietary


© 2020 Nexusguard Limited – Confidential & Proprietary
XSS payload to
bring up a
message box
that will be
saved as
user’s first
name

© 2020 Nexusguard Limited – Confidential & Proprietary


A6 – Cross Site Scripting: Prevention
Preventing XSS requires separation of untrusted data from active browser content. This can be achieved
by:

• Using frameworks that automatically escape XSS by design, such as the latest Ruby on Rails, React
JS. Learn the limitations of each framework's XSS protection and appropriately handle the use cases
which are not covered.
• Escaping untrusted HTTP request data based on the context in the HTML output (body, attribute,
JavaScript, CSS, or URL) will resolve Reflected and Stored XSS vulnerabilities. The OWASP Cheat
Sheet 'XSS Prevention' has details on the required data escaping techniques.
• Applying context-sensitive encoding when modifying the browser document on the client side acts
against DOM XSS. When this cannot be avoided, similar context sensitive escaping techniques can be
applied to browser APIs as described in the OWASP Cheat Sheet 'DOM based XSS Prevention'.
• Enabling a Content Security Policy (CSP) is a defense-in-depth mitigating control against XSS. It is
effective if no other vulnerabilities exist that would allow placing malicious code via local file includes
(e.g. path traversal overwrites or vulnerable libraries from permitted content delivery networks).

© 2020 Nexusguard Limited – Confidential & Proprietary

You might also like