建材秒知道
登录
建材号 > 厨房 > 正文

如何解压boot.img文件

凶狠的康乃馨
淡淡的紫菜
2023-03-08 01:27:09

如何解压boot.img文件

最佳答案
甜美的钢笔
诚心的世界
2025-08-16 16:22:12

在很多刷机包中都会有boot.img文件,那么这个文件到底是什么呢?其实它由两部分组成,分别为kernel 和ramdisk。kernel 也就是内核,由源代码编译而成。ramdisk是一个gz压缩包,解压后有一些文件和文件夹,里面是一些图片或者配置文件。kernel 和ramdisk以二进制的方式组合起来,就是boot.img文件。

解压boot.img文件方法:

在Windows环境下,最简单的方法就是用厨房工具来解压、合并boot.img。

Linux环境下,有专门的脚本来解压boot.img,这里不再细说。

用厨房解压boot.img的方法:

下载厨房工具,放在D盘根目录下。

进入D:\Cygwin目录,双击打开Cygwin.bat

依次输入并回车: 0 – 高级定制选项 —— 20 解包或者打包一个 boot 镜像。进入Boot 镜像工具页面

把D:\Cygwin\home目录下的user目录重命名为你的用户名(一般是Administer,我的是My)

在D:\Cygwin\home\(你的用户名)目录下新建一个WORKING_052112_083904文件夹,把boot.img文件复制到该文件夹下。再新建一个system目录

回到厨房工具,输入w并回车,就开始解压boot.img了。解压后的文件在BOOT-EXTRACTED文件夹里。

修改后,在厨房上输入b就可以重新打包boot.img了

最新回答
甜美的萝莉
传统的玉米
2025-08-16 16:22:12

①在手机上sys下是可以看到init.rc的,但是修改完之后重启就自动恢复到boot.img中的默认状态,所以我们修改的不是这个文件,而是boot.img中的init.rc

②修改boot.img

rom中是不可能直接看到init.rc这个文件的,因为它在boot.img中,如何解包打包boot.img呢?

答案是,用厨房吧......

打开厨房后,你会发现它本身就有为rom添加init.d支持的功能,当然你可以直接选择,然后一切自动完成,随后打包rom就OK了

如果想给自己进阶一下,研究到底如何手动添加这个功能,就接着看吧

第一步,解包boot.img,选择0进入高级操作菜单后,

接下来选择20,再选择w,

提示解包结束后,进入BOOT_Extract/boot.img-ramdisk下,找到init.rc,接下来就是修改它了

修改方法

1、在init.rc的class_start区域中加入(搜索class_start default,在下面之前加入;如果没有这段,搜索class_start,在前面加入,注意是另起一行)

start sysinit

复制代码

2、在最下面(service区域中)加入(直接添加到末尾就行了)

service sysinit /system/bin/logwrapper /system/xbin/busybox run-parts /system/etc/init.d

disabled

oneshot

复制代码

保存后(这个过程中厨房不要关闭了,虽然关闭也没有事,但是一直开着方便操作),用厨房选择b,回车,等待,搞定,从工作文件夹提出boot.img,线刷或者卡刷boot.img就行了

解包boot.img也可以不用厨房,不过很麻烦,这里就不说了。

幽默的裙子
舒适的香氛
2025-08-16 16:22:12

 USB调试模式是 Android 提供的一个用于开发工作的功能,使用该功能可在计算机和 Android 设备之间复制数据、在移动设备上安装应用程序、读取日志数据等等。默认情况下,USB 调试模式是关闭的,所以需要手动打开它。

USB调试功能可以通过修改ramdisk设置成开机默认打开。

1、进入boot.img-ramdisk目录下。

      2、 找到default.prop文件,找到“persist.servICe.adb.enable=0”,把其数值改成1

     3、 若无效,则在后面加入新的一行:“persist.sys.usb.config=adb”"进入boot.img-ramdisk目录"必读:

注意:

在Android系统中,要修改Ramdisk,一般都是通过调试ROM中的boot.img镜像文件来实现的。在boot.img中存放着一系列的配置脚本文件,要修改这些脚本,必通过专门的工具解压修改,而我们一般使用的工具就是“厨房(Android-Kitchen)”。

安装“厨房”的方法比较简单,我们首先需要用“厨房”解压boot.img文件,可以看到配置文件会自动保存在“BOOT-EXTRACTED/boot.img-ramdisk”这个目录下,然后我们就可以通过修改代码,实现很多有用的功能了。

追寻的汽车
敏感的玫瑰
2025-08-16 16:22:12
其实就是把boot.img放到包里,在刷机脚本里面添加上以下代码:assert(package_extract_file("boot.img", "/tmp/boot.img"), write_raw_image("/tmp/boot.img", "boot"), delete("/tmp/boot.img"))

畅快的老师
虚拟的信封
2025-08-16 16:22:12
如何用rom 助手将卡刷包转为线刷包

方法/步骤

下载安装软件 打开它、

在主界面选择你要的操作功能,ROM助手主要包括,系统精简、预装APK、系统美化、性能优化、预装LIB、信息修改、解包IMG、ROM签名、apk签名等。其中,在windows平台封装ext4的img文件是ROM助手最大的亮点,我见过很多的修改ROM包的工具,只有ROM助手可以封装IMG文件,给他们的开发团队点32个赞。。

言归正传,这里还是主要分享修改刷机包的过程和线刷包转卡刷包的教程。

一、修改ROM包

用“系统精简“功能把你要修改的ROM包加载进去,是线刷包的话就把system.img提取出来然后再加载进去。

ROM助手上面可以系统精简,内置预装、内置Lib,系统精简主要是把原ROM包里不常用的或者不是自己的推广软件清理掉,然后内置自己的推广软件,当然这些推广软件都是从联盟获取的,有的联盟需要Lib文件才能统计到量,没有特殊要求的就跳过即可。

二、线刷包转卡刷包教程

加载system.img文件会在ROM助手的安装目录生成一个文件夹,我的是D:\MoGu\Temp

这个文件夹里包含了全部system.img文件的内容,也就是上面说的在解包img,相比较其他的工具 ROM助手相对简单直接,。在这里同样可以对这个system.img进行修改。如果不想转卡刷的话,直接封装,替换到原来的位置。如果转卡刷的话 请接着往下看

自己建一个update文件夹,在update文件夹里面建一个system和META-INF文件夹,然后把上一步加载后D:\MoGu\Temp的文件全部复制到新建的update/system文件夹里,再把原线刷包的boot.img放在update里。最后也是最重要的一步,把这三个打包用签名工具签名,把官方的META-INF文件夹里的添加到刚改的这个META-INF,这样一个卡刷包就完成了。

只要是同机型的rom都可以提脚本 。

怎么用rom助手把卡刷包变成线刷包

直接下载原厂线刷包即可

到这里下载智能刷机管家 或者是下载那个线刷包 *** 文件 去里面找到你的型号的线刷ROM 下载解压后

按照里面的教程来操作就好了 pan.baidu/s/1hs4pKbU

卡刷包怎么转成线刷包?

他说这个卡刷包种茶的线刷包这个是不可能的,因为的话他这个都需要电脑里有台电脑的话直接就可以刷了

刷机包是线刷包如何改为卡刷包 详细教程

根本改不了,线刷大多是镜像文件,自己不能改,而且找不到签名。自行压缩文件会错误

求教怎么把卡刷包改成线刷包

直接下载原厂线刷包即可

到这里下载智能刷机管家 或者是下载那个线刷包 *** 文件 去里面找到你的型号的线刷ROM 下载解压后

按照里面的教程来操作就好了 pan.baidu/s/1hs4pKbU

请问如何把卡刷包改成线刷包? 10分

用rom大师,rom大师能改卡刷,也能把刷机包内置的不用ap给删除

线刷包怎么改成卡刷包

根本改不了,线刷大多是镜像文件,自己不能改,而且找不到签名。自行压缩文件会错误

线刷包怎么变为卡刷包

卡刷包,即rom 包,一般是一个 zip 压缩文件,里面有 system 文件夹和其他一两个文件夹。 线刷包,即系统底包,一般是 tg 压缩文件

安卓rom线刷包怎么改成卡刷包?求详细图文教程!回答满意~必采纳!谢谢! 10分

安卓教程:

线刷包改卡刷包教程

~首先设置我们的工作目录为 D:\U8

其次你的电脑中已经安装java,如果没有,请去网上搜索相关教程,此步骤不在本教程的介绍范围

线刷包转卡刷包

从网上下载U8线刷包然后直接解包我们只需要其中的system.img和boot.img两个文件。

现在我们需要第一个工具出场,unyaffs。在网上下载这个文件,解压缩到D:\U8\unyaffs,将上面我们解压缩的system.img文件也复制到这个目录下。进入命令行模式,到D盘U8目录的unyaffs目录下,然后输入命令unyaffs system.img, 回车,稍等一会后,会提示操作完成,这时再回到D:\U8\unyaffs目录中,就可以看到多了很多的文件和文件夹。我们在unyaffs目录下新建一个文件夹,update,然后再在update下面再建立一个文件夹system,然后将刚才unyaffs目录下多出来的(也就是从system.img中解包出来的)那些文件全部剪切到system目录下。

将boot.img文件复制到update目录下,再把META-INF.rar文件解压缩到update目录。

好了完成~下边就是打包签名了,

怎么把卡刷包转换成线刷包

用厨房解包再重新打包

暴躁的白羊
兴奋的大树
2025-08-16 16:22:12
1.安卓的闪存芯片(Flash Memory)分区结构

大家都知道C8812有4GB的ROM,我必须说这种说法很容易误导大家。这里的4GB指的是手机的闪存芯片大小是4GB,通俗的说,就是手机上有一块像SD卡一样的存储芯片(俗称字库),C8812这块芯片容量是4GB(实际小于4GB,大约在3800MB,这个是厂商原因),这块闪存芯片就像电脑的硬盘一般,被分为了很多个分区。打个比方,system分区就像电脑C盘的windows文件夹,里面全部是系统文件。而data分区就好比Program Files文件夹,安装的软件还有产生的数据全部在这里。内置卡也是从手机闪存芯片上来的一个分区,至于你插入的SD卡就相当于移动硬盘一样了。

这些分区名称通常为mmcblk0p1,mmcblk0p2等等而mmcblk0就指的是手机整块的闪存芯片。而SD卡名字则为mmcblk1p1,如果SD还有其他分区,例如swap分区,就会被命名为mmcblk1p2,而mmcblk1指的就是整块SD卡。p是分区(Partition)的意思,数字代表了第几分区。

2/9

2.安卓启动原理

当你按动电源键开机的时候,CPU通电会读取闪存芯片上固定的某个位置,这就是引导分区(bootloader),bootloader会根据用户的按键动作来决定读取recovery,boot,还是进入HBOOT,FASTBOOT等等模式。需要重点说的是boot会读取system和data分区,所以改变data分区的位置到内置卡当然是修改boot了,也就是刷机包中的boot.img。还有一点,boot.img并不是内核,这个玩意儿是内核(kernel),启动脚本(.rc)和启动程序(init)的打包。启动脚本通常会有很多个,都是后缀为.rc的文件,这些脚本由启动程序(init)释义运行。读取哪个分区作为system和data就是由启动脚本(.rc)决定,这就是我们要修改的地方。

3/9

修改方法:

1.首先你应当有厨房等工具,才能够解包boot.img得到启动脚本(.rc)文件,就不多做解释。可以参照此贴:JAVA环境搭建,厨房安装图文教程!

2.进入厨房,导入你的要修改的ROM后,选择“0“进入高级菜单,再选则”20“,就进入了解包boot.img的界面,选择”w“,然后按流程即可完成解包,进入厨房的目录,找到一个叫”BOOT-EXTRACTED“的文件夹,这个就是boot.img解包后的文件。打开我们可以看到”boot.img-ramdisk“文件夹和”zImage“文件,zImage 就是内核(kernel)我们不管它,不是我们要修改的地方。继续打开”boot.img-ramdisk“文件夹,好了看到了吧众多的.rc文件。不要眼晕,这些文件用记事本就能打开的,但是为了方便操作,我们不用记事本修改,我们需要用到EmEditor这个软件,或者你喜欢用notepad++也无妨,这里只介绍用EmEditor修改。

通过上面的原理我们知道修改启动脚本,把data分区指向内置卡就行了。C8812的原来的data分区是mmcblk0p13,即13分区。而内置卡是mmcblk0p19,即19分区。那么接下来就非常简单了,将启动脚本(.rc)里面的”mmcblk0p13“字样的改成”mmcblk0p19“,data分区就从13分区改为指向19分区了。

具体涉及到修改的时候,因为我们解包boot.img会得到很多.rc文件,例如init.huawei.rc,init.rc等等。通常需要修改的文件就是init.huawei.rc或者init.rc。

4/9

我们来看一段截取自深度OS的init.huawei.rc的代码:wait /dev/block/mmcblk0p13 #等待载入13分区exec /system/bin/e2fsck -p /dev/block/mmcblk0p13 #检查13分区mount ext4 /dev/block/mmcblk0p13 /data nosuid nodev barrier=1 noauto_da_alloc,nodelalloc#挂载13分区为/data

5/9

所以你只需要把这里的mmcblk0p13改为mmcblk0p19就ok基本啦。但是不同的boot.img里面的这段挂载代码不一定在init.huawei.rc里面,例如官方的boot.img就在init.rc里面,如果这两个文件都没有,那么你可以到其他.rc文件里寻找,这时就可以用到EmEditor的“搜索“或者”替换“可以直接将”mmcblk0p13“改成”mmcblk0p19“。我建议尽量不要一行一行的看代码手动修改,直接搜索替换更加准确可靠。

6/9

修改完毕并保存,返回到厨房的打包解包boot界面,选择”b“即可重新打包,打包后的boot.img在厨房目录下的”WORKING_XXXXX“文件夹下。对于做ROM的同学,若要提供内置卡做data支持,单独做一个boot.img补丁包,在刷入普通版后,再刷入这个boot.img补丁包即可支持内置卡分区作为data。这里有一个一样本,将你修改后的支持内置卡分区作为data的boot.img拖进这个C8812-Flash_Boot-Sample-By_Eastwife.zip即可完成补丁包制作。

7/9

3.将内置卡分区文件系统格式化为ext2或者ext3格式ext2/3是linux系统中标准的文件系统,data区必须为此文件系统才能够被识别。我在前两版深度OS支持内置卡做data都用到了分区助手这个软件来达到格式化内置卡为ext文件系统,但是大家普遍反映很麻烦。所以直接制作了两个recovery卡刷文件,一个可以将内置卡直接格式化为ext2文件系统(当然也可以达到刷机的清除数据作用),另外一个是还原内置卡为fat32格式。

8/9

后续升级和问题:1.需要还原普通版本非常容易,先刷”还原内置卡为fat32卡刷包“,然后直接卡刷普通版本刷机包即可。2.根据反映,有出现还原了内置卡为fat32格式,刷任何卡刷包依然无法识别内置卡的情况,原因尚不明确,用官方dload升级应该可以解决。3.原来的data分区空余空间如何处理?a.作为swap分区b.格式化作为新的内置卡(尚未测试)这里简单介绍下方法,因为我没有测试,所以此方法不一定可行。我们还是以截取的一段深度OS的init.huawei.rc的代码为例:wait /dev/block/mmcblk0p19 #等待19分区载入mount vfat /dev/block/mmcblk0

p19 /storage/sdcard0 uid=1000,gid=1015,umask=0002,utf8 #将19分区挂载到/storage/sdcard0,即作为内置卡。

9/9

我想能不能将mmcblk0p13分区格式化为fat32,并把这里的内置卡指向mmcblk0p13分区呢?靠大家试验了。