php imagemagick 漏洞,ImageMagick popen_utf8命令注入 漏洞报告

Author: niubl(知道创宇404安全实验室)

Date: 2016-05-07

一、漏洞概要

i. 漏洞描述

ImageMagick是一款使用量很广的图片处理程序,很多厂商都调用了这个程序进行图片处理,包括图片的伸缩、切割、水印、格式转换等等。我发现当用户传入一个包含|竖线的文件名的时候,就有可能触发命令注入漏洞。

ii. 漏洞影响

测试:ImageMagick-7.0.1-2.tar.bz2

iii. 漏洞分析

ImageMagick在处理文件名时会调用OpenBlob()函数,在OpenBlob()函数中,代码2484行,判断文件名是否以|竖线开头,如果是,那么他会调用popoen_utf8()函数处理文件名,代码如图:

92e2d486746af63288de13a0911fe7de.png

来到popoen_utf8()函数,popen_utf8()函数调用会调用popen()函数打开文件,这样就导致我们可以注入系统命令,代码如图:

dee811f06b72a053f1b7c4c25f5f5664.png

iv. 漏洞利用(PHP)

在PHP禁用执行系统命令函数的时候,我们可以用他来绕过disable_funtion,PHP编写如下代码:

new Imagick('|touch /tmp/niubl');

?>

1

2

3

newImagick('|touch /tmp/niubl');

?>

使用PHP执行,结果如图:

01fcfde66b877158fa8af3afe7ccdfa9.png

二、修复方案

目前官方已经更新代码至 Gitlab,但最终修复版本还未发布,补丁细节可参考如下链接:

三、漏洞时间线

2016.05.07    知道创宇404安全实验室niubl发现该漏洞

2016.05.29    国外研究者报告并公布了漏洞细节 http://permalink.gmane.org/gmane.comp.security.oss.general/19669

2016.05.30    发布分析报告

四、相关资源链接

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用MSYS2时,如果出现错误提示"msys2无法找到ImageMagick(缺少:imagemagick_compare_executable)",这意味着系统无法找到ImageMagick的比较可执行文件。 出现这种问题的原因可能是ImageMagick没有正确地安装在系统中,或者安装过程中没有将其路径正确地添加到环境变量中。 要解决这个问题,首先需要确保ImageMagick已经正确地安装在系统中。可以通过访问ImageMagick的官方网站,下载适合您系统的安装包,并按照指示进行安装。 安装完成后,需要将ImageMagick的路径添加到系统的环境变量中,以便MSYS2能够找到它。可以按照以下步骤进行操作: 1. 在Windows操作系统中,右键单击桌面上的"我的电脑",然后选择"属性"。 2. 在打开的窗口中,选择"高级系统设置"。 3. 在"系统属性"窗口中,选择"高级"选项卡,然后点击"环境变量"按钮。 4. 在"系统变量"部分,找到名为"Path"的变量,并点击"编辑"按钮。 5. 在弹出的编辑系统变量窗口中,点击"新建"按钮,然后输入ImageMagick的安装路径。 通常情况下,ImageMagick的安装路径为"C:\Program Files\ImageMagick"。 6. 确保输入完整后,点击"确定"按钮,然后连续关闭所有打开的窗口。 完成上述步骤后,重新启动MSYS2,并再次尝试执行相关的操作。此时系统应该能够找到并正常使用ImageMagick了。 希望这个回答对你有帮助!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值