hacktricks/pentesting-web/unicode-injection/README.md

75 lines
5.4 KiB
Markdown
Raw Normal View History

2024-02-11 02:07:06 +00:00
# Unicode-injectie
2022-09-02 10:02:33 +00:00
<details>
2024-02-11 02:07:06 +00:00
<summary><strong>Leer AWS-hacking vanaf nul tot held met</strong> <a href="https://training.hacktricks.xyz/courses/arte"><strong>htARTE (HackTricks AWS Red Team Expert)</strong></a><strong>!</strong></summary>
2022-09-02 10:02:33 +00:00
2024-02-11 02:07:06 +00:00
Andere manieren om HackTricks te ondersteunen:
2022-09-02 10:02:33 +00:00
2024-02-11 02:07:06 +00:00
* Als je je **bedrijf geadverteerd wilt zien in HackTricks** of **HackTricks in PDF wilt downloaden**, bekijk dan de [**ABONNEMENTSPAKKETTEN**](https://github.com/sponsors/carlospolop)!
* Koop de [**officiële PEASS & HackTricks-merchandise**](https://peass.creator-spring.com)
* Ontdek [**The PEASS Family**](https://opensea.io/collection/the-peass-family), onze collectie exclusieve [**NFT's**](https://opensea.io/collection/the-peass-family)
* **Doe mee aan de** 💬 [**Discord-groep**](https://discord.gg/hRep4RUj7f) of de [**telegram-groep**](https://t.me/peass) of **volg** ons op **Twitter** 🐦 [**@carlospolopm**](https://twitter.com/hacktricks_live)**.**
* **Deel je hacktrucs door PR's in te dienen bij de** [**HackTricks**](https://github.com/carlospolop/hacktricks) en [**HackTricks Cloud**](https://github.com/carlospolop/hacktricks-cloud) github-repos.
2022-09-02 10:02:33 +00:00
</details>
2024-02-11 02:07:06 +00:00
## Inleiding
2022-09-02 10:02:33 +00:00
2024-02-11 02:07:06 +00:00
Afhankelijk van hoe de back-end/front-end zich gedraagt wanneer het **vreemde unicode-karakters ontvangt**, kan een aanvaller mogelijk **beveiligingsmaatregelen omzeilen en willekeurige karakters injecteren** die kunnen worden gebruikt om **injectiekwetsbaarheden** zoals XSS of SQLi te misbruiken.
2022-09-02 10:02:33 +00:00
2024-02-11 02:07:06 +00:00
## Unicode-normalisatie
2022-09-02 10:02:33 +00:00
2024-02-11 02:07:06 +00:00
Unicode-normalisatie treedt op wanneer **unicode-karakters worden genormaliseerd naar ASCII-karakters**.
2022-09-02 10:02:33 +00:00
2024-02-11 02:07:06 +00:00
Een veelvoorkomend scenario van dit type kwetsbaarheid doet zich voor wanneer het systeem de **invoer** van de gebruiker **aanpast nadat deze is gecontroleerd**. Bijvoorbeeld, in sommige talen kan een eenvoudige oproep om de **invoer in hoofdletters of kleine letters te zetten** de gegeven invoer normaliseren en de **unicode zal worden omgezet in ASCII**, waardoor nieuwe karakters worden gegenereerd.\
Voor meer informatie, zie:
2022-09-02 10:02:33 +00:00
{% content-ref url="unicode-normalization.md" %}
[unicode-normalization.md](unicode-normalization.md)
{% endcontent-ref %}
2024-02-11 02:07:06 +00:00
## `\u` naar `%`
2022-09-02 10:02:33 +00:00
2024-02-11 02:07:06 +00:00
Unicode-karakters worden meestal weergegeven met het **voorvoegsel `\u`**. Bijvoorbeeld het karakter `㱋` is `\u3c4b`([controleer het hier](https://unicode-explorer.com/c/3c4B)). Als een back-end de prefix **`\u` transformeert in `%`**, zal de resulterende string `%3c4b` zijn, wat URL-gecodeerd is als: **`<4b`**. En, zoals je kunt zien, wordt er een **`<`-teken geïnjecteerd**.\
Je kunt deze techniek gebruiken om **elk soort teken** in te voegen als de back-end kwetsbaar is.\
Bekijk [https://unicode-explorer.com/](https://unicode-explorer.com/) om de karakters te vinden die je nodig hebt.
2022-09-02 10:02:33 +00:00
2024-02-11 02:07:06 +00:00
Deze kwetsbaarheid komt eigenlijk voort uit een kwetsbaarheid die een onderzoeker heeft gevonden, voor een meer gedetailleerde uitleg zie [https://www.youtube.com/watch?v=aUsAHb0E7Cg](https://www.youtube.com/watch?v=aUsAHb0E7Cg)
2022-09-02 10:02:33 +00:00
2024-02-11 02:07:06 +00:00
## Emoji-injectie
2022-09-02 10:02:33 +00:00
2024-02-11 02:07:06 +00:00
Back-ends gedragen zich soms vreemd wanneer ze **emoji's ontvangen**. Dat is wat er gebeurde in [**deze write-up**](https://medium.com/@fpatrik/how-i-found-an-xss-vulnerability-via-using-emojis-7ad72de49209) waar de onderzoeker erin slaagde om een XSS te bereiken met een payload zoals: `💋img src=x onerror=alert(document.domain)//💛`
2022-09-02 10:02:33 +00:00
2024-02-11 02:07:06 +00:00
In dit geval was de fout dat de server na het verwijderen van de schadelijke karakters de UTF-8-string **van Windows-1252 naar UTF-8 converteerde** (in feite kwam de invoerencodering niet overeen met de conversie-encodering). Hierdoor wordt er geen juist <-teken gegeven, maar een vreemd unicode-teken: ``\
``Dus ze namen deze uitvoer en **converteerden deze opnieuw van UTF-8 naar ASCII**. Dit **normaliseerde** de `` naar `<`, zo kon de exploit werken op dat systeem.\
Dit is wat er gebeurde:
2022-09-02 10:02:33 +00:00
```php
<?php
$str = isset($_GET["str"]) ? htmlspecialchars($_GET["str"]) : "";
$str = iconv("Windows-1252", "UTF-8", $str);
$str = iconv("UTF-8", "ASCII//TRANSLIT", $str);
echo "String: " . $str;
```
2024-02-11 02:07:06 +00:00
Emoji-lys:
2022-09-02 10:02:33 +00:00
* [https://github.com/iorch/jakaton\_feminicidios/blob/master/data/emojis.csv](https://github.com/iorch/jakaton\_feminicidios/blob/master/data/emojis.csv)
* [https://unicode.org/emoji/charts-14.0/full-emoji-list.html](https://unicode.org/emoji/charts-14.0/full-emoji-list.html)
<details>
2024-02-11 02:07:06 +00:00
<summary><strong>Leer AWS-hacking van nul tot held met</strong> <a href="https://training.hacktricks.xyz/courses/arte"><strong>htARTE (HackTricks AWS Red Team Expert)</strong></a><strong>!</strong></summary>
2022-09-02 10:02:33 +00:00
2024-02-11 02:07:06 +00:00
Ander maniere om HackTricks te ondersteun:
2022-09-02 10:02:33 +00:00
2024-02-11 02:07:06 +00:00
* As jy jou **maatskappy geadverteer wil sien in HackTricks** of **HackTricks in PDF wil aflaai**, kyk na die [**SUBSCRIPTION PLANS**](https://github.com/sponsors/carlospolop)!
* Kry die [**amptelike PEASS & HackTricks swag**](https://peass.creator-spring.com)
* Ontdek [**The PEASS Family**](https://opensea.io/collection/the-peass-family), ons versameling eksklusiewe [**NFTs**](https://opensea.io/collection/the-peass-family)
* **Sluit aan by die** 💬 [**Discord-groep**](https://discord.gg/hRep4RUj7f) of die [**telegram-groep**](https://t.me/peass) of **volg** ons op **Twitter** 🐦 [**@carlospolopm**](https://twitter.com/hacktricks_live)**.**
* **Deel jou hacktruuks deur PR's in te dien by die** [**HackTricks**](https://github.com/carlospolop/hacktricks) en [**HackTricks Cloud**](https://github.com/carlospolop/hacktricks-cloud) github-repos.
2022-09-02 10:02:33 +00:00
</details>