安防IP Camera固件分析

liwenhaosuper 2014-08-21 16:48:00

0x00 背景


之前一直看的是传统的系统安全问题,最近了解了下嵌入式设备的安全,颇有意思。

首先要从下面一个图说起:

这是由一位匿名的黑客通过端口探测等方式得到的2012年全球可攻击利用的嵌入式设备热点分布图,被叫做“Internet Census of 2012”,具体更详尽信息可见其网站:Internet Census of 2012

这些设备完全就是在互联网上裸跑,不管是管理员还是黑客都可以随意控制它们。

跟传统的现代处理器保护机制不一样,这些嵌入式设备处理器很多都没有我们习以为常的如虚拟内存、特权级等的概念,如何保护他们的安全目前是研究界的一大热点,USENIX Security 2013有篇论文是专门针对这些问题讨论的,叫Sancus: Low-cost trustworthy extensible networked devices with a zero-software Trusted Computing Base

既然嵌入式设备都在裸跑,那么研究下它们里面的东西,作进一步分析是非常有必要的。

0x01 细节


接下来要考虑的是研究哪种嵌入式设备,选择路由器?好像乐趣不多;前几天看了部电影《风暴》,我对里面警察通过监控摄像头查找证据的场景印象深刻,当时浮现的想法是:如果匪徒也能控制这些监控摄像头,反过来通过它们监控警察的行踪,或者在他们作案前或作案后将监控摄像头的数据删除掉,那么警匪的力量就不会这么悬殊,剧情会不会更有意思?

在现实生活中,如果我作为黑客能够控制所有的摄像头,如室内的家庭安防,那是多么可怕的场景:

摄像头的本意的用于防护别人保护自己安全,而一旦被人利用了就可能反过来自己遭受监控!由此目标就锁定在安防摄像头上了。

首先面临的问题是如何找到目标设备?最直接的方法是通过它们暴露的接口:它们必须与客户端连接!

那么就找个客户端:vMEyeSuper,google一下看到这个博客http://www.petsdreampark.com/blog/archives/2726提供的设备地址:pdp.ns01.biz,然后就是找机会入侵啦:端口扫描,暴力破解。

通过工具发现设备的telnet是可登录的,然后就是暴力破解,用户名密码一下子就出来了(user name: root, password就不贴了)。试了下,成功登录进去,root权限哦!

登陆进去后它打印显示“welcome to monitor tech”,“嗯,不客气,反正我都来了”。先查看系统信息吧:

可看到系统用的是ucLinux,内核是3.0.8,处理器是ARM926EJ-S,芯片是海思的Hi3518,google一些这方面的信息,海思的hi3XXX都是有名的安防解决方案,海思的SDK可在这里下载。

找了一番发现系统就是一个ucLinux内核加一个busybox组成的,核心IPC固件在/usr/bin下,ps一下看到进程主要是Sofia和dvrbox,而关键是Sofia。:

重启Sofia可以看到一系列log信息,其中它开了一个web server,目录在/mnt/web下。

我想做的一个事情是将所有有用的文件拷贝下来分析,因为看到里面有用户名、密码信息等,但是由于busybox提供的工具太少了,关键是ssh,scp, wget, ftp等这些都没有,没办法上传下载,真是无奈:没有现有的工具,有root权限能干的事情也很有局限性呀!

想到它开有web server,于是打算将文件放到/mnt/web下再从浏览器下载下来。可惜不成功:目录只读!

想到一个办法:虽然/mnt/web下是只读的cramfs文件系统,可通过mount mtd到/mnt/web下覆盖原有目录做到:

mount -t jffs2 /dev/mtdblock5 /mnt/web

总算顺利将所有文件都拖下来了!

分析发现searchIp、Sofia执行文件都用了upx进行压缩的,需要先进行解压。然后就用IDA Pro进行反汇编分析了。

分析发现searchIp是作为一个server用于被客户端扫描发现并主动连接到Sofia的工具。

基于此,只要写个扫描工具就能够发现并登录同厂商大量的裸露安防摄像头设备了!

接下来有空的话要做的事情就是尝试扫描网络发现这些设备并利用google map组成一个摄像头监控网络。

目前尚未解决的问题:由于无法物理接触到这些设备,系统busybox里面又没有可用的工具,尚不能上传文件到设备上。

评论

动后河 2014-08-21 17:27:05

透着这些摄像头, liwenhaosuper 一直在默默地保护着地球

Z

zeracker 2014-08-21 18:45:32

很赞! 我喜欢可视化

路人甲 2014-08-21 23:56:30

ctOS...

J

JulyTornado 2014-08-22 08:45:35

最近搞过类似的设备,是运营商的光猫,mips架构的cpu,貌似tmp目录可写。。。

C

CplusHua 2014-08-22 12:56:25

也没有tar,echo嘛?/dev/tcp/ip/port

C

CplusHua 2014-08-22 12:57:03

ctOS已经连线

路人甲 2014-08-22 16:30:43

我一点儿看不出来这有什么意思!

X

xiao.k 2014-08-22 21:35:57

既然能telnet进去 还没办法传文件? echo “x” > file

路人甲 2014-08-25 09:25:36

为了世界的和平,我是不会轻易告诉你busybox自带ftpget和put的

路人甲 2014-11-16 04:48:50

Would you be able to share the password for Telnet?

L

liwenhaosuper

System Security and Mobile Security Researcher.

twitter weibo github wechat

随机分类

Windows安全 文章:88 篇
APT 文章:6 篇
Python安全 文章:13 篇
企业安全 文章:40 篇
Exploit 文章:40 篇

扫码关注公众号

WeChat Offical Account QRCode

最新评论

Article_kelp

因为这里的静态目录访功能应该理解为绑定在static路径下的内置路由,你需要用s

N

Nas

师傅您好!_static_url_path那 flag在当前目录下 通过原型链污

Z

zhangy

你好,为什么我也是用windows2016和win10,但是流量是smb3,加密

K

k0uaz

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

Yukong

🐮皮

目录