提取摄像头固件中应用逻辑代码

所需工具:

file 用来查看文件类型

strings 用来获取文件中所有的字符串

binwalk 用来提取和分离固件

firmware-mod-kit 分析固件的瑞士军刀了,能做很多事,以后有机会写一系列的firmware-mod-kit相关博客。

  • 固件分析

首先用binwalk分析固件格式,即固件中包含了哪些文件。
binwalk firmware.bin

  • 提取文件系统

提取出文件系统的指令需要加个-e:
binwalk -e firmware.bin
提取出来的文件系统包括:squshfs和jffs2.
这时候我们想找应用的关键逻辑,一般都是在文件系统的bin文件夹下。所以下一步就是提取文件系统中的文件。一般binwalk会在-e的时候就帮我们把squashfs中的文件提取出来,命名为:squashfs-root。而JFFS2文件系统binwalk却没有处理,因此需要我们额外的提取出jffs2的文件。

  • firmware-mod-kit安装

这里利用firmware-mod-kit。
先下载:git clone https://github.com/mirror/firmware-mod-kit.git
Ubuntu需要安装依赖:sudo apt-get install git build-essential zlib1g-dev liblzma-dev python-magic
进入src目录:
cd firmware-mod-kit/src
编译:
./configure && make

  • 提取jffs2文件系统

进入firmware-mod-kit下的jffs2目录:
cd /firmware-mod-kit/src/jffs2
执行unjffs2:
sudo ./unjffs2 970000.jffs2 
此时就得到了名为jffs2-root的文件夹,里面就是关键代码了。
这时候我们进入到文件系统的bin目录下,就可以看见应用程序的可执行文件,放入到IDA中进行分析。

    原文作者:FunctionY
    原文地址: https://blog.csdn.net/doudoudouzoule/article/details/86017841
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞