freeBuf
主站

分类

漏洞 工具 极客 Web安全 系统安全 网络安全 无线安全 设备/客户端安全 数据安全 安全管理 企业安全 工控安全

特色

头条 人物志 活动 视频 观点 招聘 报告 资讯 区块链安全 标准与合规 容器安全 公开课

点我创作

试试在FreeBuf发布您的第一篇文章 让安全圈留下您的足迹
我知道了

官方公众号企业安全新浪微博

FreeBuf.COM网络安全行业门户,每日发布专业的安全资讯、技术剖析。

FreeBuf+小程序

FreeBuf+小程序

PDF漏洞(CVE-2018-12794)浅析
四维创智4DOGS 2019-05-08 15:02:01 259680

 漏洞简介 

CVE-2018-12794属于类型混淆漏洞,产生漏洞原因是通过构建XML数据包(XML Data Package,XDP)模版,并对XML表单体系结构(XML Forms Architecture,XFA)对象执行某些JavaScript操作,攻击者就可以强制Adobe Reader从模版对象的边界引用数据。

2018年7月份,Adobe补丁更新:

漏洞基本信息

漏洞ID:CVE-2018-12794

漏洞名称:PDF类型混淆漏洞

漏洞类型:远程代码执行

威胁类型:类型混淆

影响版本:影响2018.011.20040及之前版本


 漏洞测试 

系统环境:Win7 32

Adobe Reader:2018.011.20040

PoC:https://github.com/thezdi/PoC/tree/master/CVE-2018-12794


 PoC分析 

XML Data Package(XDP)是Adobe Systems创建的XML 文件格式。该格式允许将PDF内容或Adobe XML Forms Architecture(XFA)资源打包在XML 容器中。XDP符合XML 1.0的规范,可以作为独立文档,也可以在PDF文档中携带。XDP提供了一种在XML容器中打包表单组件的机制,XDP还可以打包PDF文件以及XML表单和模板数据。

006quPLGly1g2twzmhcrhj30vn0smqic.jpg


第1个object流对象里面的XFA(XML Forms Architecture)对象会执行Java代码,该代码会操作sub1和sub2,先将sub1添加为xfa.template对象,sub2添加为xfa.from对象,然后将sub2附加到sub1。

006quPLGly1g2twzysjudj30vi0e87c1.jpg

最后执行Java代码将o2的presence属性设置为inactive ,该属性的含义为隐藏对象并将其从事件处理中排除。在执行该操作的时候将触发crash。


 调试分析 

通过gflags 开启页堆后,用Windbg附加Adobe Acrobat DC打开PoC文件。程序会停在发生crach的位置。

006quPLGly1g2tx09w470j30vo06m0ux.jpg


从上面调试信息中可以看到,异常出现在AcroForm.api模块,ecx的值异常导致程序crash,通过栈回溯可以定位到crash的上一层函数AcroForm!PlugInMain+0x979f1,反汇编该函数并观察ecx的值(ecx的值是直接传入crash函数使用)。

006quPLGly1g2tx0ew6c8j30kp05qtag.jpg


反汇编代码后发现ecx的值来自[eax+esi*8],而esi只是一个偏移且为0,故ecx的值与eax有关,来自[edi+1d4h]。该地址的值是一些字符串,由此推测,是把该字符串的值当成了指针来引用,从而导致crash。

006quPLGly1g2tx0tj46mj30jm0b9wh1.jpg


经多次调试发现[edi+1d4h]每次的值都不同,这个地址的值是未知的,如下图。

006quPLGly1g2tx108guoj30jl0b4q5g.jpg


使用堆命令查看edi所在的空间大小为140h,猜测是一个对象指针或者一块申请的内存空间,而[edi+1d4h]显然已经是越界访问。

006quPLGly1g2tx1jc0t3j30dl00fdfn.jpg


从代码中知道为XFA对象,参考《SyScan3602016-_Pwning_Adobe_Reader_with_XFA》报告


中给出的关于XFA内部对象的识别办法获取Type-IDs。使用uf poi(poi(对象地址)+8)的命令可以显示出Type-IDs。

4d6ab30c9a361cc2a70f85dae6137d99

可以看到类型为7C00h,说明了该堆块保存的就是一个XFA对象。

46176dcaef821e31f9cc9782ede29991

通过交叉引用得到 XFATemplateModelImpl  的虚表,再通过交叉引用构造函数就能找到这个对象大小为 140h 字节。

60a1b9160567d8789765c11cbc601eaa

在XFATemplateModelFactoryImpl::newModel函数中可以看到申请了140h字节的空间,从函数名猜测这里是new一个大小为140h的Template对象。

在虚表进行交叉引用可定位到相应的初始化Form对象的地址,Form对象申请的空间大小是270h, [edi+1d4h]的地址实际应该是读取的Form对象中的值,Template对象大小是140h,所以漏洞的根本原因是代码在处理Template对象时使用了Form对象的函数进行处理,造成了类型混淆漏洞。

参考资料

https://github.com/siberas/arpwn/blob/master/slidedecks/SyScan360_2016_-_Pwning_Adobe_Reader_with_XFA.pdf

https://xz.aliyun.com/t/4262

http://blogs.adobe.com/formfeed/2009/03/xfa_30_presenceinactive.html

更多漏洞播报:四维创智


# 漏洞分析
免责声明
1.一般免责声明:本文所提供的技术信息仅供参考,不构成任何专业建议。读者应根据自身情况谨慎使用且应遵守《中华人民共和国网络安全法》,作者及发布平台不对因使用本文信息而导致的任何直接或间接责任或损失负责。
2. 适用性声明:文中技术内容可能不适用于所有情况或系统,在实际应用前请充分测试和评估。若因使用不当造成的任何问题,相关方不承担责任。
3. 更新声明:技术发展迅速,文章内容可能存在滞后性。读者需自行判断信息的时效性,因依据过时内容产生的后果,作者及发布平台不承担责任。
本文为 四维创智4DOGS 独立观点,未经授权禁止转载。
如需授权、对文章有疑问或需删除稿件,请联系 FreeBuf 客服小蜜蜂(微信:freebee1024)
被以下专辑收录,发现更多精彩内容
+ 收入我的专辑
+ 加入我的收藏
四维创智
四维创智4DOGS LV.3
四维创智(北京)科技发展成立于2013年,是国际技术领先的智能网络安全产品和服务提供商。 主营业务涵盖应用安全、系统安全、运维安全等,先后推出自主研发的多款智能化检测产品,并针对行业不同需求,提供不同的行业解决方案及安全检测、渗透测试、风险评估、网络安全培训等服务,与能源(电力)、军工、金融等领域合作,是国家高新企业、专精特新企业,中关村信息安全产业联盟成员单位,国家信息技术安全研究中心联盟单位。
  • 53 文章数
  • 7 关注者
我国互联网遭境外网络攻击:地址多来自美国
2022-03-16
愚人节不 “愚”丨干货分享! TXPortMap实用型免费渗透测试工具
2021-04-01
红队必备:WEB蜜罐识别阻断插件
2020-08-17