实践中,面向公共互联网供给服务的体系或服务器,都是处于边际方位的。所以无论是物联网设备仍是企业级服务器,只要能被外界访问到,那就会无时无刻被进犯。 最近,咱们发现了一种进犯方法,多个公司Apache Tomcat Web服务器重复遭受感染。一般由于忧虑端点反病毒软件会下降服务器的功用或形成服务器不稳定,所以服务器办理员并没有装置相应的防护东西。明显,这种主意在现在看来很过期。 这种情况下,尽管服务器办理员保证现已将操作体系及Apache组件更新到最新版别,但每逢处理完感染问题没多久,又呈现了相同的问题。 走运的是,服务器办理员供给了捕获到的包括进犯行为的网络数据包。这种进犯看起来很眼熟,由于在咱们布置的蜜罐中,就曾见到这种自动化投递歹意ku软件的进犯行为。可是在这之前,还未见过在野进犯成功的事例,所以咱们决议经过剖析捕获的数据包来解说这次进犯是怎么施行的。
猫(Tomcat)和老鼠 侵略成功的根本原因在于办理员在Tomcat办理页面中运用了弱口令。初始阶段的进犯是在Tomcat办理面板对登录凭证进行暴力破解,一旦进犯者成功以办理员身份登录,那一切都完了。 在得到正确的登录凭证后,进犯者会对服务器建议HTTP POST恳求,如下图所示:
图1:进犯者经过HTTP POST上传新的的admin.jsp页面 在Tomcat办理页面答应办理员以扩展名为.war的文件方式将Web运用程序上传到服务器。此刻进犯者上传了一个名为admin-manager.war的.war文件,该文件中包括了一个名为admin.jsp的歹意JSP文件。一旦该文件被外部进犯者调用,就会生成方针服务器装备信息文件。 admin.jsp文件如下所示:
图2:admin.jsp文件搜集方针体系的装备信息,并能够履行指令 Admin.jsp有三个功用:搜集体系装备信息,在Apache服务器上创立新文件,以及运用Web服务器帐户的权限在服务器上履行指令。 进犯者能够运用“ act ” 指令(猜想为“action”的简写),指定相应参数,然后加上一个或两个选项。三个参数(SI,、SH、 UF)用处如下:System Information (act=SI)System Information函数将回来比如OS、主机名、用户名等信息。 File Creation (act=UF)当“upload file”被调用,进犯者所发送的Base64字符将写入到Apache服务器的一个文件中。 Command execution (act=SH)取决于正在运转Tomcat服务器的操作体系,此“shell”指令将测验运用/ bin / bash(* nix服务器)、Windows指令行或PowerShell履行指令。还支撑对指令字符串进行Base64编码。 两个选项的阐明如下: String Parameter1 = request.getParameter ( “p1” ) 假如参数为SH代表内容进行Base64编码 假如参数为UF代表为文件命名 String Parameter2 = request.getParameter ( “p2” ) 假如参数为SH代表True 假如参数为UF代表将Base64转为blob
ku软件投递 例如,进犯者一开始会向服务器建议字段内容为act = SI的HTTP POST恳求,服务器的呼应如下图:
图3 从回来中能够看出这个Tomcat布置在64位Windows Server 2012核算机上,还回来了主机称号(为了隐私,咱们打了马赛克),以及歹意.jsp文件的寄存途径。至于标题中的“Hello,Peppa!(你好,佩奇)”,咱们猜想进犯者可能是小猪佩奇的粉丝。 出于某种原因,进犯者履行两次此指令,彼此相隔一秒。 接下来,进犯者宣布了一个action= SH&p2 = True&p1 =(base64)的“SH”指令,如下所示:
图4 解码后如内容下:
图5 该脚本首先会测验杀死WMIC.exe,RegSvr32.exe和PowerShell.exe进程,然后查看体系是否存在PowerShell 1.0的文件途径(%systemroot% System32 WindowsPowerShell v1.0 PowerShell.exe)。假如它在体系中找到该途径,将履行base64编码中的blob数据(上图中黄色高亮显现部分)。 假如脚本找不到PowerShell的途径,它将运用RegSvr32.exe从C2服务器下载并履行名为init.gif的文件。并运用脚本com目标(scrobj.dll)来履行init.gif的内容。 在PCAP中,能够看到进犯者履行指令后服务器的呼应。如下图,进犯者宣布指令时服务器未运转以上三个进程,所以这部分指令没有并履行成功。 [1][2][3]黑客接单网