解压 Android 系统中的 system.img

转自:https://www.jianshu.com/p/db70835d41c8

system.img 是什么

system.img 是 Android 系统中用来存放系统文件的镜像 (image) ,文件格式为 yaffs2 或者 ext 的文件系统 ,在 Android 源码编译后会生产该文件。它将被 init 进程通过解析 init.rc 文件挂载 (mount) 到 /system 目录或者说 system 分区下

如何制作 system.img

使用下面的命令来即可制作一个 system.img

$ make_ext4fs -s -T 1421464178 -S file_contexts -l 1073741824 -a system system.img system/

命令说明
make_ext4fs用于制作 Android 平台上 ext4 文件系统的镜像
参数说明
-s 表示安静处理,不输出动作,可选参数
-T 表示 Unix 时间戳,对 system.img 中的文件设置修改时间
-S 表示 sepolicy 的 file_contexts
-l 表示最大的文件大小(受限于分区大小)
-a 表示 Android 的挂载(mount)点,比如 system、userdata、recovery,make_ext4fs 会根据 private/android_filesystem_config.h 里定义好的权限来给文件夹里的所有文件重新设置权限,如果不指定 -a 参数,则使用默认权限
system.img 表示输出文件名
system/ 表示输入目录,该目录下有 framework、app、bin 等目录
命令执行完成后,会得到一个经过压缩的 system.img ,无法直接进行mount,我们后面具体会介绍如何查看 system.img 中的内容

如何解压 system.img

system.img 是包含在系统刷机包里面的,解压刷机包,通常会有两种情况

直接得到 system.img

在 Android 5.0 以前的版本(不包含 5.0),通过解压刷机包可以直接得到 system.img ,而 system.img 可能是 raw、yaffs2 或者 ext 的文件系统
使用 file 命令可以区分 system.img 的文件系统格式

$ file system.img

如果输出是 Linux rev 1.0 ext4 filesystem data ,则表明是 raw 文件
如果输出是 VMS Alpha executable ,则表明是 yaffs2 文件
如果输出是 data ,则表明是 ext 文件

查看 raw 格式的 system.img 内容

Linux rev 1.0 ext4 filesystem data 表明 system.img 是一个完整的分区镜像,可以直接用于挂载,使用下面的命令即可查看 system 的内容

$ mkdir system
$ sudo mount -t ext4 system.img system

解压 yaffs2 格式的 system.img

下载 unyaffs 源码,然后执行下面命令编译得到 unyaffs 可执行文件

$ gcc -o unyaffs unyaffs.c

创建一个 system 目录,将 unyaffs 和 system.img 放到 system 目录中,然后执行命令,即可解压到当前目录

$ unyaffs system.img

解压 ext 格式的 system.img

首先,需要用 simg2img 工具把 system.img 转为为 ext4 文件格式,该工具位于 out/host/linux-x86/bin/simg2img
工具用法

https://codeload.github.com/KinglyWayne/simg2img_win/zip/master

$ simg2img system.img system.ext4.img

会得到一个 system.ext4.img ,它是 raw 格式的完整镜像,可以使用上面介绍的方法进行查看

刷机包中无 system.img

在 Andriod 5.0 以后的版本,为了降低update.zip文件的大小和写入的数据量,所有的ROM包,都仿照增量包的方式进行打包了,我们解压刷机包,会得到以下三个带有 system 的文件

system.new.dat
system.patch.dat
system.transfer.list

system.new.dat文件实际上是由system.transfer.list描述的一个稀疏数组,使用 sdat2img 工具即可转换得到真正的 system.img

$ sdat2img system.transfer.list system.new.dat system.img

前两个参数分别是 trans list 文件和输入的 system.new.dat 文件,最后一个是输出的 system.img 文件名,生成的文件可以直接用于 ext4 的 mount

参考链接

1、android中system.img的打包过程
2、system.img 解压和压缩
3、Android中system.img的两种格式及其相互转换方法
4、yaffs文件打包解包工具
5、Android5.0的更新包中system.new.dat文件的解包



作者:为何是Hex的昵称
链接:https://www.jianshu.com/p/db70835d41c8
來源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用方法:http://blog.csdn.net/asmcvc/article/details/11770851 工具: unyaffs,mkyaffs2image 其unyaffs有windows版本和linux版本,mkyaffs2image只有linux版本。 windows版本的unyaffs用法: 把system.img复制到unyaffs的相同目录下,cmd命令下cd到unyaffs的目录下,然后执行命令:unyaffs system.img unyaffs会把system.img解压到其目录下。 linux版本的unyaffs用法: 把unyaffs复制到/usr/bin目录下,并修改权限为可执行。 然后cd到system.img目录下(假定目录为system目录),执行命令:unyaffs system.img 然后对system目录下的文件进行修改。 注意:修改完后的文件要修改一下权限,尽量和其他文件的权限保持一致。例如:chmod 644 framework-res.apk mkyaffs2image用法: 复制到/usr/bin目录下,并修改权限为可执行。 这里以打包system目录为system.img为例,执行命令: mkyaffs2image system system.img 然后把新生成的system.img复制替换掉原:adt-bundle-windows-x86\sdk\system-images\android-17\armeabi-v7a\system.img 执行bat批处理命令启动模拟器: D:\adt-bundle-windows-x86\sdk\tools\emulator-arm.exe -avd AndroidVM -partition-size 128 这里以修改android系统启动画面为例: 打开解包目录下的\framework\framework-res.apk 替换图片:framework-res.apk\assets\images\android-logo-mask.png为下图: 然后对\framework\framework-res.apk文件重新签名,复制到linux下后修改文件权限和原来一致。 然后mkyaffs2image system system.img打包生成新的system.img,替换原来的system.img,并启动模拟器,效果图如下: 修改代码: 工具:odextools(参考:《一键odex批量合并工具odextools的重新整理与使用》)、dexopt-wrapper 其odextools.bat的代码: 批处理有一处bug:每打包一次会把odex文件删除掉,导致在后面的打包过程会出现找不到:system/framework/core.odex类似的错误,因此只需要在打包完后不删除odex文件即可,找到del /f !apkx!.odex 1>nul 2>nul改为:::del /f !apkx!.odex 1>nul 2>nul,也就是注释掉这一行代码。 具体使用方法(操作在windows下): 在odextools\romdir目录下创建文件夹:system 利用unyaffs解包system.img后,把所有文件复制到system目录下。 然后运行odextools.bat,如图: 选择一个需要整合odex的目录选项即可。odextools.bat会自动设置环境变量,使用baksmali.jar来反编译odex为smali,然后再调用smali.jar打包为classes.dex, 然后再打包到相应的apk包(framework目录下对应的是jar后缀的,实际上也是个apk包),最后再重新签名。 如果要修改代码,则需要把上面重新打包生成的apk文件,利用常规方法反编译后修改smali代码,例如插桩输入log信息。然后再回编译并重新签名。 最后一步:因为system.img的apk是优化过的,apk主目录下是没有classes.dex文件的,而是一个被优化过的odex文件,用于优化启动速度。 因此需要将修改后的apk包再用dexopt-wrapper优化apk包后生成出odex文件,然后删除apk包里的classes.dex,并在相同目录下放置与apk包同名的odex文件。 按照原system目录的文件结构组织好后,目录复制到linux环境下使用mkyaffs2image重新打包成system.img
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值