为什么说破壳漏洞会带来一场全球服务器的浩劫

948ebbff490bbb3c8cfa7863ee55c721

2014 年 9 月 24 日,Bash 惊爆严重安全漏洞,编号为 CVE-2014-6271,该漏洞将导致远程攻击者在受影响的系统上执行任意代码。GNU Bash 是一个为 GNU 计划编写的 Unix Shell,广泛使用在 Linux 系统内,最初的功能仅是一个简单的基于终端的命令解释器。这意味全球至少 150 万的主机将受到影响,此外 Linux/Unix 世界内的安卓和苹果都难幸免。

破壳漏洞(ShellShock)的严重性被定义为 10 级(最高),今年 4 月爆发的 OpenSSL「心脏出血」漏洞才 5 级!

漏洞描述:

GNU Bash 4.3 及之前版本在评估某些构造的环境变量时存在安全漏洞,向环境变量值内的函数定义后添加多余的字符串会触发此漏洞,攻击者可利用此漏洞改变或绕过环境限制,以执行 Shell 命令。某些服务和应用允许未经身份验证的远程攻击者提供环境变量以利用此漏洞。此漏洞源于在调用 Bash Shell 之前可以用构造的值创建环境变量。这些变量可以包含代码,在 Shell 被调用后会被立即执行。

影响情况:

这个破壳漏洞确实是一个危害极大的漏洞,胜于今年 4 月 8 号爆发的「心脏出血」,但破壳漏洞的探测方式很复杂,不同的组件测试方式有所区别,很难评估一个影响面,但是可以肯定的是 Bash<=4.3 版本都受影响,而 Bash 在至少百亿级别数量的设备上使用,因为 Bash 是最流行的 Linux Shell。

来自知道创宇的 ZoomEye 团队通过几种方式的组合检测,得到了些影响结论。

第一组数据

经过 ZoomEye 的特殊探测,发现国内某厂家的互联网系统在全国范围内有 13254 台设备受到破壳漏洞影响,可被直接远程攻击。

第二组数据

经过 ZoomEye 的 Fuzzing 探测,全球大概存在 142000 主机受影响,需要注意的是由于 Fuzzing 规则不完备,得到的数量肯定会不完备,但这个数字至少可以看到可被直接远程攻击利用的面很大。

第三组数据

我们看到 masscan 的官方发布了消息: http://blog.erratasec.com/2014/09/bash-shellshock-bug-is-wormable.html 他们全球探测的结论是:至少 150 万受影响,而这验证规则很简单,仅对主机的 80 端口进行直接请求,这个结论我们也在验证。

可以从这几组数据看到,探测方式各不相同,如果继续扩展可以逐步描绘出越来越清晰的影响面(可直接远程攻击),知道创宇会继续。

破壳漏洞几个有趣点:

  1. 危害等级是 10(不能再高了),心脏出血那么厉害才 5;
  2. 破壳破的是 Bash,这个在 Linux/Unix 世界存活超过了 20 来年;
  3. 破壳蠕虫已经传播感染;
  4. 虽然这是 Linux/Unix 世界的问题,别忘了安卓、苹果都是(需要深入验证),当然 Windows 这次没事;
  5. 破壳漏洞的利用比心脏出血麻烦,怪不得带来的冲击力低了很多,很多媒体都没关注也可理解,但破壳的后劲绝对很大。

此漏洞可能会影响到的地方

注:以下几点参考自:https://raw.githubusercontent.com/citypw/DNFWAH/master/4/d4_0x07_DNFWAH_shellshock_bash_story_cve-2014-6271.txt

且结论经过我们验证有效。

  1. 在 SSHD 配置中使用了 ForceCommand 用以限制远程用户执行命令,这个漏洞可以绕过限制去执行任何命令。一些 Git 和 Subversion 部署环境的限制 Shell 也会出现类似情况,OpenSSH 通常用法没有问题。
  2. Apache 服务器使用 mod_cgi 或者 mod_cgid,如果 CGI 脚本在 BASH 或者运行在子 Shell 里都会受影响。子 Shell 中使用 C 的 system/popen,Python 中使用 os.system/os.popen,PHP 中使用 system/exec(CGI 模式) 和 Perl 中使用 open/system 的情况都会受此漏洞影响。
  3. PHP 脚本执行在 mod_php 不会受影响。
  4. DHCP 客户端调用 Shell 脚本接收远程恶意服务器的环境变量参数值的情况会被此漏洞利用。
  5. 守护进程和 SUID 程序在环境变量设置的环境下执行 Shell 脚本也可能受到影响。
  6. 任何其他程序执行 Shell 脚本时用 Bash 作为解释器都可能受影响。Shell 脚本不导出的情况下不会受影响。

漏洞验证,可以使用如下命令来检查系统是否存在此漏洞:

CVE-2014-6271 测试方式:

  1. env x='() { :;}; echo vulnerable' bash -c "echo this is a test"

注:CVE-2014-6271 的漏洞源码级分析请参考: http://blog.knownsec.com/2014/09/bash_3-0-4-3-command-exec-analysis/

修补后,又被绕过,CVE-2014-7169 最新测试方法:

  1. $ env -i X='() { (a)=>\' bash -c 'echo date'; cat echo

如执行结果如下则仍然存在漏洞:

  1. bash: X: line 1: syntax error near unexpected token `='
  2. bash: X: line 1: `'
  3. bash: error importing function definition for `X'
  4. Wed Sep 24 14:12:49 PDT 2014

暂时还没最靠谱的通用修复方案,关注 Bash 的下一次升级。

原文发布时间:2014-09-26

本文来自云栖合作伙伴“linux中国”

为什么说破壳漏洞会带来一场全球服务器的浩劫相关推荐

  1. bash破壳漏洞分析(二)

    1. Bash简介 1.1 定义    Bash(GNU Bourne-Again Shell)是许多Linux发行版的默认Shell. 1.2 概述    目前的Bash使用的环境变量是通过函数名称 ...

  2. 破壳漏洞(CVE-2014-6271)综合分析

    目 录 一. 威胁卡片  二. 概述  三. 已知事件发布/披露情况 四. 漏洞的影响范围  五. 漏洞原理  六. 漏洞验证方法  七. 漏洞检测方法  八. 漏洞可能会带来的影响  九. 针对此漏 ...

  3. 一不小心,我们办了场全球最 _____ 的技术大会......

    开个玩笑,大会是真的,"大企划"倒不至于."最大规模"."最多人数"."最......",听上去确实唬人,但加上&quo ...

  4. 修复linux bash破壳漏洞,Linux系统下如何检测并修复bash中的破壳漏洞​​

    问题:我想要知道我的Linux服务器是否存在bash破壳漏洞,以及如何来保护我的Linux服务器不受破壳漏洞侵袭. 2014年9月24日,一位名叫斯特凡·沙泽拉的安全研究者发现了一个名为"破 ...

  5. CVE-2014-6271 “破壳“ 漏洞

    前言 CVE-2014-6271(即"破壳"漏洞)广泛存在与GNU Bash 版本小于等于4.3的*inux的系统之中,只要目标服务器开放着与Bash相交互的应用与服务,就有可能成 ...

  6. NSA泄密事件之SMB系列远程命令执行漏洞及Doublepulsar后门全球数据分析

    本文讲的是NSA泄密事件之SMB系列远程命令执行漏洞及Doublepulsar后门全球数据分析, 1.   概述 2017 年 4 月 14 日,黑客组织Shadow Brokers 公布了一批新的N ...

  7. linux 破壳漏洞,Bash破壳漏洞

    "破壳"是一个严重漏洞的别名,在Red Hat.CentOS.Ubuntu.Fedora.Amazon Linux.OS X 10.10中均拥有存在CVE-2014-6271(即& ...

  8. 修复linux bash破壳漏洞,Linux下bash破壳漏洞检测及修复的方法

    如果Linux服务器存在bash破壳漏洞,将可能导致远程攻击者操作系统来执行任意命令,威胁等级较高,我想要知道我的Linux服务器是否存在bash破壳漏洞,以及如何来保护我的Linux服务器不受破壳漏 ...

  9. 基于破壳漏洞的蠕虫实践

    基于破壳漏洞的蠕虫实践 本实验介绍了一款基于shellshock漏洞的简单蠕虫程序,通过本实验,你可以了解蠕虫的使用与传播方式,也可以亲自动手随心所欲的改造这款蠕虫程序. 实验简介 实验所属系列:操作 ...

最新文章

  1. C语言实现方差variance计算(附完整源码)
  2. java properties读取缓存_Java读取Properties文件
  3. 完整国内城市js级联选择
  4. 微服务的概念——《微服务设计》读书笔记
  5. HBase 手动 flush 机制梳理
  6. 抖音国际版TikTok因收集儿童信息在美被罚570万美元
  7. redis key/value 前面出现\xac\xed\x00\x05t\x00\x06 已解决
  8. 普通人能用华为P30拍出银河么?这是我们在北京实拍的结果
  9. 「开源资讯」Apache Storm 2.2.0 发布,分布式实时计算
  10. svn 服务器中文件删除,svn中如何彻底删除一个文件
  11. Java入门基础 安装并配置Java软件和JDK
  12. 钢琴乐谱怎么看?学习五线谱及其口诀
  13. Springboot 整合Rabbit MQ
  14. Reactjs开发基础
  15. M40Z-025003TB0西克光电开关 订货号: 1200128
  16. Python OpenCV 3.x 示例:6~11
  17. 华为 Mate40系列发布,你的5G绝版手机来了!
  18. [问题已处理]-mac安装cobra失败
  19. 长大后才知道,成年人的哭原来没有声音
  20. ipad下添加126邮箱账户

热门文章

  1. Tuxera NTFS21Mac苹果电脑读取硬盘磁盘软件
  2. 你知道 kubectl exec 的运行机制是什么吗?
  3. 苹果6s出现连接不上服务器未响应,苹果6s的蜂窝移动数据打开没反应怎么办
  4. 图割论文阅读笔记:“GrabCut” — Interactive Foreground Extraction using Iterated Graph Cuts
  5. html5保护环境作品,保护环境的绘画作品图片
  6. ibdata1是什么?
  7. 相关性指标RMSE/PLCC/SROCC/KROCC理解
  8. 15/18位身份证号码验证的正则表达式总结(详细版)
  9. 组态王图素制作_组态王实例教程入门
  10. 武大c语言网上作业答案,武大C语言题库