自定义OTA升级包(差分包,增量包,增量更新)

2023-10-31 15:31

本文主要是介绍自定义OTA升级包(差分包,增量包,增量更新),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

OTA是Over-the-Air的简写,空中下载技术的意思,OTA升级包,就是一种可以使用网络或者SD卡给手机进行升级的一种文件包,相当于给系统打补丁的一种方法,其原理是通过recovery升级的功能进行实现的。Recovery提供的功能如下,使用apply update from sdcard功能即可升级OTA包。这种升级方式也可以通过adbroot/adb remount/adb push指令实现,但是需要连接到电脑PC端,且支持adb才行。


1、  使用ota_from_target_files脚本生成制作差分包

参考博客:http://blog.csdn.net/mike8825/article/details/47871481

make otapackage——会生成sd卡用的全部系统升级包,如

Y:\slm753_2\LA.BR.1.2.4-05310-8x16.0\out\target\product\slm753\obj\PACKAGING\target_files_intermediates\slm753-target_files-eng.Data.BU.zip

此时修改代码,重新编译make;make otapackage

第二次生成slm753-target_files-eng.Data.BU.zip,然后使用脚本,生成两个包之间的查分包:

./build/tools/releasetools/ota_from_target_files  -i <A包> <B包>  <差分包名>

升级的过程就是按照升级脚本:updater-script指定的动作来的,下面会介绍自定义升级包的过程,以及updater-script升级脚本的语法。

2、  DIY制作OTA差分包

在out下面的产品目录下会生出一些OTA的包,最基本的空包组成如下截图:

Y:\slm753_2\LA.BR.1.2.4-05310-8x16.0\out\target\product\slm753\


其中update-binary是一个二进制文件,相当于一个脚本解释器,能够识别updater-script中描述的操作。updater-script就是前面说的升级脚本,具体描述了更新过程。我们可以根据具体情况编写该脚本来适应我们的具体需求。

参考:http://www.verydemo.com/demo_c131_i81124.html

一个较为完整的OTA升级包如下:

 update.zip包的目录结构

          |----boot.img
          |----system/
          |----recovery/
               `|----recovery-from-boot.p
                `|----etc/
                       `|----install-recovery.sh
          |---META-INF/
              `|CERT.RSA
              `|CERT.SF
              `|MANIFEST.MF
              `|----com/
                    `|----google/
                            `|----android/
                                   `|----update-binary
                                   `|----updater-script
                            `|----android/
                                   `|----metadata

我们来看一下一个ChinaMobile的升级包,实现的功能就是更新system下面的几个文件。

为了实现更新系统system下面的几个文件需要,在升级脚本写入如下内容,主要包括:

mount("ext4","EMMC","/dev/block/bootdevice/by-name/system","/system");//挂载system

mount("ext4","EMMC","/dev/block/bootdevice/by-name/userdata","/data");//挂载Userdata

package_extract_dir("system","/system");//提取升级包内目录中的所有文件到指定的目标目录

run_program("/system/bin/sh","/system/vendor/speccfg/switch_spec.sh","/system/vendor","","","/system/vendor/speccfg/spec");//以指定的参执行程序

unmount("/system");//卸载system

unmount("/data");//卸载data

        

update.zip包的签名:update.zip更新包在制作完成后需要对其签名,否则在升级时会出现认证失败的错误提示。而且签名要使用和目标板一致的加密公钥。加密公钥及加密需要的三个文件在Android源码编译后生成的具体路径为:

              out/host/linux-x86/framework/signapk.jar 

              build/target/product/security/testkey.x509.pem        

              build/target/product/security/testkey.pk8 。

             我们用命令make otapackage制作生成的update.zip包是已签过名的,如果自己做update.zip包时必须手动对其签名。具体的加密方法:

$ java –jargingerbread/out/host/linux/framework/signapk.jar –w

gingerbread/build/target/product/security/testkey.x509.pem                                    

gingerbread/build/target/product/security/testkey.pk8update.zip update_signed.zip 以上命令在update.zip包所在的路径下执行,其中signapk.jartestkey.x509.pem以及testkey.pk8文件的引用使用绝对路径。

本例使用的签名指令

Java -jarout/host/linux-x86/framework/signapk.jar -w

build/target/product/security/platform.x509.pembuild/target/product/security/platform.pk8 ./ideaWallpaper.apk ideaWallpaper2.apk

至此 升级包已经打包签名完毕!可以放入SD卡或者通过网络下载升级。如果使用SD卡升级,需要同时按住power键和音量键,进入recovery模式。

3、updater-script语法

参考:http://www.banxiayue.com/updater_script.html

updater-script命令详解,刷机脚本怎么写,这些问题都也算是安卓的入门知识了,今天就和大家讲解一下,讲解人是深度论坛的Seeyou,如果你想学习更多ROM制作安卓开发方面的知识,欢迎加入深度DRT团队,我们从初级到高级给大家系统的讲解。
命令:mount
用法:mount(fs_type, partition_type, location, mount_point)
参数讲解:
fs_type—————–“yaffs2″ 或 “ext4″
partition_type———-“MTD” 或 “EMMC”
location—————–分区(partition) 或 驱动器(device)
mount_poin————挂载文件系统的目标文件夹(target folder to mount FS)
作用解释: 挂载一个文件系统到指定的挂载点
返 回 值: 挂载成功则返回挂载点,失败返回null
函数示例: mount(“MTD”, “system”, “/system”);挂载system分区,设置返回指针”/system”
mount(“vfat”, “/dev/block/mmcblk1p2″, “/system”); 挂载/dev/block/mmcblk1p2,返回指针”/system”

命令: format
用法: format(fs_type, partition_type, location)
参数详解:
fs_type—————–字符串,数据为”yaffs2″ 或“ext4″
partition_type———-字符串, “MTD” 或“EMMC”
location—————–字符串, 分区(partition)或 驱动器(device)
作用解释: 格式化为指定的文件系统
函数示例: format(“MTD”, “system”);格式化system分区

命令: delete
用法: delete(file1, file2, …, fileN)
参数详解: 字符串,要删除的文件
作用解释: 删除一个文件。最少指定一个文件;多个文件可以做为多个参数指定
函数示例: delete(“/data/zipalign.log”);删除文件/data/zipalign.log

命令:delete_recursive
用法: delete_recursive(dir1, dir2,…,dirN)
参数详解: 字符串,要递归删除的目录
作用解释: 删除文件夹及其包含的所有内容。最少指定1个目录;多个目录可以做为多个参数指定
函数示例: delete_recursive(“/data/dalvik-cache”);删除文件夹/data/dalvik-cache

命令:show_progress
用法: show_progress(frac, sec)
参数详解:
frac———————-进度完成数值
Sec———————-总秒数
作用解释: 显示在Recovery系统中进度
函数示例: show_progress(0.1, 10);show_progress下面的操作可能进行10s,完成后进度条前进0.1(也就是10%)

命令:set_progress
用法: set_prograss(frac)
参数详解: frac———————进度数值
函数示例:

命令:package_extract_dir
用法: package_extract_dir(package_path, destination_path)
参数详解:
package_path———-字符串,升级包内要提取的目录
destination_path——–字符串,提取文件的目标目录
作用解释: 提取升级包内目录中的所有文件到指定的目标目录
函数示例: package_extract_dir(“system”, “/system”);释放ROM包里system文件夹下所有文件和子文件夹至/system

命令:package_extract_file
用法: package_extract_file(package_path) 或package_extract_file(package_path, destination_path)
参数详解:
package_path———-字符串,升级包内要提取的文件
destination_path——-字符串,提取文件的目标目录
作用解释: 提取升级包内的单个文件到指定的目标目录
函数示例: package_extract_file(“my.zip”, “/system”);解压ROM包里的my.zip文件至/system

命令:file_getprop
用法: file_getprop(file, key)
参数详解:
file———————-字符串,要检查的文件名
Key———————-字符串,返回数据中的文件的键名字
作用解释: 在格式”key”=”value”的文件中取得文件属性值
函数示例:

命令: symlink
用法: symlink(target, src1, src2, …, srcN)
参数详解:
target——————-字符串,符号链接的目标
srcX        ———————字符串,要创建的符号链接的目标点
作用解释: 在创建新的符号链接之前,要断开已经存在的符号链接
函数示例: symlink(“toolbox”, “/system/bin/ps”);建立指向toolbox的符号链接/system/bin/ps

命令: set_perm
用法: set_perm(uid, gid, mode, file1, file2, …, fileN)
参数详解:
uid———————-用户ID(user id)
Gid———————-用户组ID(group id)
Mode——————–权限模式(permission mode)
fileX———————要设置许可的文件(file to set permission on)
作用解释: 设置单个文件或一系列文件的权限,最少指定1个文件,前4个参数是必须的
函数示例: set_perm(0,2000,0550, “system/etc/init.goldfish.sh”);设置手机system中的etc/init.goldfish.sh的用户为root,用户组为shell,所有者以及所属用户组成员可以进行读取和执行操作,其他用户无操作权限)
这里0代表用户为root
2000代表用户组为shell
我们来说明0550这组数据,这组数据的最后三位550,分别代表“所有者\组用户\其他用户”的权限,也就是我们在RE管理中“用户\群组\其他”三行。 我们以XXX来表示这三组权限,其中:
×=4 读的权限
×=2 写的权限
×=1 执行的权限
我们必须首先了解用数字表示的属性的含义:0表示没有权限,1表示可执行权限,2表示可写权限,4表示可读权限,然后将其相加。所以数字属性的格式应为3个从0到7的八进制数。
例如,如果想让某个文件的属主有”读/写”二种权限,需要把4(可读)+2(可写)=6(读/写)。若要rwx属性则4+2+1=7;若要rw-属性则4+2=6;若要r-x属性则4+1=5。
常用修改权限的命令:
Set_perm 0 0 0600 ××× (只有所有者有读和写的权限)
Set_perm 0 0 0644 ××× (所有者有读和写的权限,组用户只有读的权限)
Set_perm 0 0 0700 ××× (只有所有者有读和写以及执行的权限)
Set_perm 0 0 0666 ××× (每个人都有读和写的权限)
Set_perm 0 0 0777 ××× (每个人都有读和写以及执行的权限)

命令:set_perm_recursive
用法: set_perm_recursive(uid, gid, dirmode, filemode, dir1, dir2, …dirN)
参数详解:
uid———————-用户ID(user id)
Gid———————-用户组ID(group id)
Dirmode—————-指定目录内的目录的权限
Filemode—————指定目录内的文件的权限
dirX———————要设置权限的目标
作用解释: 设置单个目录或一系列目录的里面的所有文件的权限,最少指定1个目录,5个参数都是必须的
函数示例: set_perm_recursive 0 0 0755 0644 SYSTEM:app;设置手机system/app文件夹及其中文件的用户为root,用户组为root,app文件夹权限为所有者可以进行读、写、执行操作,其他用户可以进行读取和执行操作,其中的文件的权限为所有者可以进行读写操作,其他用户可以进行读取操作

命令: getprop
用法: getprop(key)
参数详解: key———————字符串,想要系统返回的属性
作用解释: 这个函数是用来返指定的属性的值。它是用来从build.props文件中查询手机的信息的。
函数示例:

命令:write_raw_image
用法: write_raw_image(file, partition)
参数详解:
file———————-字符串,要读取的Img源文件
Partition—————–字符串,要写入Img文件的目标分区
作用解释: 这个函数是用来写Img文件到分区
函数示例: write_raw_image(“/tmp/boot.img”, “boot”)将yaffs2格式的boot包直接写入boot分区

命令:apply_patch
用法: apply_patch(srcfile, tgtfile, tgtsha1, tgtsize, sha1_1, patch_1,…, sha1_x, patch1_x)
参数详解:
srcfile——————-字符串,要打补丁的源文件(要读入的文件)
Tgtfile——————-字符串,补丁文件要写入的目标文件
tgtsha1—————–字符串,写入补丁文件的目标文件的sha1哈希值
sha1_x——————字符串,要写入目标文件的补丁数据的sha1哈希值 patch1_x—————-字符串,实际上应用到目标文件的补丁
作用解释: 这个函数是用来打补丁到文件。
函数示例:

命令:apply_patch_check
用法: apply_patch_check(file, sha1_1, …, sha1_x)
参数详解:
file———————-字符串,要检查的文件
sha1_x——————要检查的哈希值
作用解释: 检查文件是否已经被打补丁,或者能不能被打补丁。需要检查“applypatch_check ”函数调用的源代码。

命令:apply_patch_space
用法: apply_patch_space(bytes)
参数详解: bytes——————-检查的字节的数字
作用解释: 检查缓存来确定是否有足够的空间来写入补丁文件并返回一些数据。
函数示例:

命令:read_file
用法: read_file(filename)
参数详解: filename—————-字符串,要读取内容的文件名
作用解释: 这个函数返回文件的内容
函数示例:

命令:sha1_check
用法: sha1_check(data) 或 sha1_check(data,sha1_hex, …, sha1_hexN)
参数详解:
data———————要计算sha1哈希值的文件的内容-必须是只读文件格式
sha1_hexN————–文件数据要匹配的特定的十六进制sha1_hex哈希值字符串
作用解释: 如果只指定data参数,这个函数返回data参数的十六进制sha1_hex哈希值字符串。其他参数用来确认你检查的文件是不是列表中的哈希值的一个。它返回匹配的哈希值,或者在没有匹配任何哈希值时返回空。
函数示例:

命令: ui_print
用法: ui_print(msg1, …, msgN)
参数详解: msg———————-字符串,要处理过程中输出给用户的信息
作用解释: 在脚本运行的时候,在控制台显示的信息。最少要指定1个参数,你可以指定额外的msg参数,并且它们会连接起来输了
函数示例: ui_print(“It’s ready!”);屏幕打印It’s ready!

命令:run_program
用法: run_program(prog, arg1, .., argN)
参数详解:
prog——————–字符串,要执行的程序
argN——————–字符串,要执行的程序的运行参数
作用解释: 以指定的参执行程序
函数示例: run_program(“/system/xbin/installbusybox.sh”);运行installbusybox.sh脚本文件

命令: ifelse
用法: ifelse(condition, truecondition, falsecondition)
参数详解:
condition—————-要运算的表达式
Truecondition———–当值为True时执行的Edify脚本块
Falsecodnition———–当值为False时执行的Edify脚本块
作用解释: 这是If-then结构的 Edify脚本语言。在真条件或非条件下语句可以是单条Edify命令或者脚本块。脚本块可以用圆括号来界定,用分号来隔开。
函数示例:

命令: abort
用法: abort()
参数详解: 没有参数
作用解释: 中止脚本执行
函数示例:

命令: assert
用法: assert(condition)
参数详解: condition—————boolean
作用解释: 如果condition参数的计算结果为False,则停止脚本执行,否则继续执行脚本
函数示例:assert(package_extract_file(“boot.img”,”/tmp/boot.img”),write_raw_image(“/tmp/boot.img”,”boot”),delete(“/tmp/boot.img”))
执行package_extract_file,如果不返回错误则执行write_raw_image,如果write_raw_image不出错则执行delete。




这篇关于自定义OTA升级包(差分包,增量包,增量更新)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/316338

相关文章

Ubuntu 24.04 LTS怎么关闭 Ubuntu Pro 更新提示弹窗?

《Ubuntu24.04LTS怎么关闭UbuntuPro更新提示弹窗?》Ubuntu每次开机都会弹窗提示安全更新,设置里最多只能取消自动下载,自动更新,但无法做到直接让自动更新的弹窗不出现,... 如果你正在使用 Ubuntu 24.04 LTS,可能会注意到——在使用「软件更新器」或运行 APT 命令时,

SpringBoot 自定义消息转换器使用详解

《SpringBoot自定义消息转换器使用详解》本文详细介绍了SpringBoot消息转换器的知识,并通过案例操作演示了如何进行自定义消息转换器的定制开发和使用,感兴趣的朋友一起看看吧... 目录一、前言二、SpringBoot 内容协商介绍2.1 什么是内容协商2.2 内容协商机制深入理解2.2.1 内容

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

poj3468(线段树成段更新模板题)

题意:包括两个操作:1、将[a.b]上的数字加上v;2、查询区间[a,b]上的和 下面的介绍是下解题思路: 首先介绍  lazy-tag思想:用一个变量记录每一个线段树节点的变化值,当这部分线段的一致性被破坏我们就将这个变化值传递给子区间,大大增加了线段树的效率。 比如现在需要对[a,b]区间值进行加c操作,那么就从根节点[1,n]开始调用update函数进行操作,如果刚好执行到一个子节点,

hdu1394(线段树点更新的应用)

题意:求一个序列经过一定的操作得到的序列的最小逆序数 这题会用到逆序数的一个性质,在0到n-1这些数字组成的乱序排列,将第一个数字A移到最后一位,得到的逆序数为res-a+(n-a-1) 知道上面的知识点后,可以用暴力来解 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#in

hdu1689(线段树成段更新)

两种操作:1、set区间[a,b]上数字为v;2、查询[ 1 , n ]上的sum 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<queue>#include<set>#include<map>#include<stdio.h>#include<stdl

hdu 1754 I Hate It(线段树,单点更新,区间最值)

题意是求一个线段中的最大数。 线段树的模板题,试用了一下交大的模板。效率有点略低。 代码: #include <stdio.h>#include <string.h>#define TREE_SIZE (1 << (20))//const int TREE_SIZE = 200000 + 10;int max(int a, int b){return a > b ? a :

poj 3159 (spfa差分约束最短路) poj 1201

poj 3159: 题意: 每次给出b比a多不多于c个糖果,求n最多比1多多少个糖果。 解析: 差分约束。 这个博客讲差分约束讲的比较好: http://www.cnblogs.com/void/archive/2011/08/26/2153928.html 套个spfa。 代码: #include <iostream>#include <cstdio>#i

AI行业应用(不定期更新)

ChatPDF 可以让你上传一个 PDF 文件,然后针对这个 PDF 进行小结和提问。你可以把各种各样你要研究的分析报告交给它,快速获取到想要知道的信息。https://www.chatpdf.com/

poj 3169 spfa 差分约束

题意: 给n只牛,这些牛有些关系。 ml个关系:fr 与 to 牛间的距离要小于等于 cost。 md个关系:fr 与 to 牛间的距离要大于等于 cost。 隐含关系: d[ i ] <= d[ i + 1 ] 解析: 用以上关系建图,求1-n间最短路即可。 新学了一种建图的方法。。。。。。 代码: #include <iostream>#include