1
0
mirror of https://github.com/danog/psalm.git synced 2024-12-03 18:17:55 +01:00
psalm/docs/running_psalm/issues/TaintedTextWithQuotes.md

44 lines
1.6 KiB
Markdown
Raw Normal View History

# TaintedTextWithQuotes
Emitted when user-controlled input that can contain quotation marks can be passed into to an `echo` statement.
## Risk
This could lead to a potential Cross Site Scripting (XSS) vulnerability. Using a XSS vulnerability, an attacker could inject malicious JavaScript and execute any action JavaScript could do. Examples include:
- Stealing authentication material (e.g. cookies, JWT tokens)
- Exfiltrate sensitive information by reading the DOM
- Keylog entries on the website (e.g. fake login form)
2021-08-05 22:39:01 +02:00
Whether this is exploitable or not depends on a few conditions:
- Is an executable mimetype set? (e.g. `text/html`)
- Is the content served inline or as attachment? (`Content-Disposition`)
- Is the output properly sanitized? (e.g. stripping all HTML tags or having an allowlist of allowed characters)
## Example
```php
<?php
$param = strip_tags($_GET['param']);
?>
<script>
console.log('<?=$param?>')
</script>
```
2022-08-20 23:29:03 +02:00
Passing `');alert('injection');//` as a `GET` param here would cause the `alert` to trigger.
## Mitigations
2021-06-10 23:55:07 +02:00
- Sanitize user input by using functions such as `htmlentities` with the `ENT_QUOTES` flag or use an allowlist.
- Set all cookies to `HTTPOnly`.
- Consider using Content Security Policy (CSP), to limit the risk of XSS vulnerabilities.
- If user input itself is HTML, see [Sanitizing HTML User Input](../../security_analysis/avoiding_false_positives.md#sanitizing-html-user-input)
## Further resources
- [OWASP Wiki for Cross Site Scripting (XSS)](https://owasp.org/www-community/attacks/xss/)
- [Content-Security-Policy - Web Fundamentals](https://developers.google.com/web/fundamentals/security/csp)