Bashlite恶意软件阴魂未散-智能设备面临新考验


Bashlite恶意软件阴魂未散:智能设备面临新考验

0x01 概况


早在2014年,Shell Shock(CVE-2014-6721)便作为一个高达10级的漏洞受到极大的关注,而利用Shell Shock疯狂作案的Bashlite恶意软件在当时已对不少设备造成了威胁,这其中包括了路由器、手机、可穿戴设备等。近日,360 QVM团队又捕获了该恶意程序的最新变种,并追踪到了相关多个平台的恶意程序,相比老版的bashlite,新版支持的平台更多,且成功率更高,多种智能设备将受到Bashlite恶意软件影响。

0x02 样本分析


该版本一共有25个文件,其中包括一个shell脚本文件和24个elf文件,支持不同架构的设备,如下表:

文件名文件类型
lntaELF 32-bit LSB executable, ARM, version 1, dynamically linked (uses shared libs), not stripped
lntbELF 32-bit LSB executable, ARM, version 1, dynamically linked (uses shared libs), not stripped
lntcELF 32-bit LSB executable, ARM, version 1 (SYSV), dynamically linked (uses shared libs), not stripped
lntdELF 32-bit LSB executable, Intel 80386, version 1 (SYSV), dynamically linked (uses shared libs), not stripped
lnteELF 32-bit MSB executable, Motorola 68020, version 1 (SYSV), dynamically linked (uses shared libs), not stripped
lntfELF 32-bit LSB executable, Intel 80386, version 1 (SYSV), dynamically linked (uses shared libs), not stripped
lntgELF 32-bit LSB executable, MIPS, MIPS-I version 1 (SYSV), dynamically linked (uses shared libs), not stripped
lnthELF 32-bit MSB executable, MIPS, MIPS-I version 1 (SYSV), dynamically linked (uses shared libs), not stripped
lntiELF 32-bit MSB executable, PowerPC or cisco 4500, version 1 (SYSV), dynamically linked (uses shared libs), not stripped
lntjELF 32-bit MSB executable, PowerPC or cisco 4500, version 1 (SYSV), dynamically linked (uses shared libs), not stripped
lntkELF 32-bit LSB executable, Renesas SH, version 1 (SYSV), dynamically linked (uses shared libs), not stripped
lntlELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked (uses shared libs), not stripped
nt.shPOSIX shell script text executable
slntaELF 32-bit LSB executable, ARM, version 1, statically linked, not stripped
slntbELF 32-bit LSB executable, ARM, version 1, statically linked, not stripped
slntcELF 32-bit LSB executable, ARM, version 1 (SYSV), statically linked, not stripped
slntdELF 32-bit LSB executable, Intel 80386, version 1 (SYSV), statically linked, not stripped
slnteELF 32-bit MSB executable, Motorola 68020, version 1 (SYSV), statically linked, not stripped
slntfELF 32-bit LSB executable, Intel 80386, version 1 (SYSV), statically linked, not stripped
slntgELF 32-bit LSB executable, MIPS, MIPS-I version 1 (SYSV), statically linked, not stripped
slnthELF 32-bit MSB executable, MIPS, MIPS-I version 1 (SYSV), statically linked, not stripped
slntiELF 32-bit MSB executable, PowerPC or cisco 4500, version 1 (SYSV), statically linked, not stripped
slntjELF 32-bit MSB executable, PowerPC or cisco 4500, version 1 (SYSV), statically linked, not stripped
slntkELF 32-bit LSB executable, Renesas SH, version 1 (SYSV), statically linked, not stripped
slntlELF 64-bit LSB executable, x86-64, version 1 (SYSV), statically linked, not stripped

文件名:nt.sh
文件大小:21.9kb
MD5: c14761119affea9569dd248a0c78d0b4

该程序可用于更新作者本身写的程序,也用于将已感染bashlite的主机占为己有,我们来看看它的主要功能:

先清除了老版本使用的配置文件,并杀掉了老版本的进程;

下载并并运行最新的恶意程序,这里使用了curl、lynx、wget等多种方式下载,确保下载成功;

当确认与服务端建立连接后则停止。

其它文件:

其它文件完成了主要的恶意功能,不同文件为不同平台所打造,但功能都是类似的,以80386平台为例,我们来看看slntd的主要功能:

先简单的strace一下该程序:

可以看到该程序先设置了线程名,随后连接了8.8.8.8,然后读取了路由表,之后的操作都是由几个线程完成,我们详细的跟一下:

1.使用prctl修改线程名为[cpuset]

2.连接8.8.8.8来判断用户是否已连接到网络,若连接到网络则通过路由表来获得ip地址并得到设备名称,再由ioctl得到mac地址:

3.连接C&C地址(162.248.79.66)

简单对该地址扫描,发现其开放了21,22端口,我们尝试着访问一下:

可以看到上面有作者用于交叉编译的工具和脚本,还有已生成好的bot文件,从nt2.sh可以看到有新的地址188.209.49.163:443,而且底部有_Generated Mon, 26 Oct 2015 10:38:23 GMT by proxy (squid/3.1.23)_,由此可见作者可能已经拥有了大量的肉鸡,已经必须使用squid来承受并发的压力,当然也有可能仅仅是为了隐藏自己。

4.接受远程发来的指令,与老版本相似,支持一下几种指令:

指令功能
PING给服务端发送"PONG!",应为上线提示功能
GETLOCALIP给服务端发送本机IP
SCANNER执行StartTheLelz函数,随机生成IP地址,并尝试使用弱口令连接去感染更多主机
HOLD,JUNK,UDP,TCP针对远程发来的IP和不同攻击指令,对目标主机发动DOS攻击
KILLATTK终止所有攻击
LOLNOGTFO卸载

值得一提的是SCANNER指令,执行该指令时会尝试连接大量的随机地址,占用资源明显。

若主机存在,则尝试使用telnet方式感染主机,被感染后的主机仍可以继续寻找其它可被感染的目标。

0x03 总结


Bashlite危害较大,其新版本不光会影响到设备的性能,占用大量网络资源,还有可能会造成隐私泄露等危害,360QVM小组提醒各智能设备厂商做好防范措施,固件使用高版本的BASH,且不要使用弱口令作为验证手段。管理员们要时刻注意主机的异常进程和网络流量情况。

评论

路人甲

真正的路人甲.

twitter weibo github wechat

随机分类

MongoDB安全 文章:3 篇
运维安全 文章:62 篇
逻辑漏洞 文章:15 篇
memcache安全 文章:1 篇
渗透测试 文章:154 篇

扫码关注公众号

WeChat Offical Account QRCode

最新评论

K

k0uaz

foniw师傅提到的setfge当在类的字段名成是age时不会自动调用。因为获取

Yukong

🐮皮

H

HHHeey

好的,谢谢师傅的解答

Article_kelp

a类中的变量secret_class_var = "secret"是在merge

H

HHHeey

secret_var = 1 def test(): pass

目录