Android系统recovery刷机脚本updater-script语法说明
这篇教程部分说明来源于网络,主要为了让大家了解updater-script语法和使用,以及熟悉权限的定义和如何使用
unmount
• unmount(mount_point);
• mount_point---是mount设置产生的值。作用与挂载相对应,卸载分区或设备。此函数与mount配套使用。
• unmount("/system"); 卸载/system分区
• 复制代码
• format(type, location);
• type="MTD" location=partition(分区),location参数代表分区。
• format("MTD", "system"); 格式化system分区
• 复制代码
• mount(type, location, mount_point);
• type="MTD" location="" 挂载yaffs2文件系统分区;type="vfat" location="/dev/block/" 挂载设备。
• mount("MTD", "system", "/system"); 挂载system分区,返回值"/system”
• mount("ext4", "/dev/block/mmcblk1p2", "/system"); 挂载/dev/block/mmcblk1p2,返回值"/system”/system分区格式为ext4
• mount("vfat", "/dev/block/mmcblk1p2", "/system"); 挂载/dev/block/mmcblk1p2,返回值"/system”/system分区格式为vfat
• 复制代码
• delete();删除文件
• delete("/data/zipalign.log"); 删除文件/data/zipalign.log
• 复制代码
• delete_recursive();删除文件夹
• delete_recursive("/data/dalvik-cache");删除文件夹/data/dalvik-cache
• 复制代码
• show_progress(,);为下面进行的程序操作显示进度条,进度条会根据设置的参数前进
• show_progress(0.1, 10);show_progress下面的操作可能进行10s,完成后进度条前进0.1(也就是10%)
• 复制代码
• package_extract_dir(package_path, destination_path);解压package_path文件夹到destination_path目录
• package_extract_dir("system", "/system"); 解压ROM包里system文件夹下所有文件和子文件夹至/system目录
• 复制代码
• package_extract_file(package_path, destination_path);解压package_path文件到destination_path目录
• package_extract_dir("my.zip", "/system"); 解压ROM包里的my.zip文件到/system目录
• 复制代码
• symlink(...);建立指向target符号链接src1,src2,也就是软链接
• symlink("toolbox", "/system/bin/ps");建立指向toolbox的符号链接/system/bin/ps
• 复制代码
• set_perm(...);设置文件的用户为uid,用户组为gid,权限为mode
• set_perm(1002, 1002, 0440, "/system/etc/dbus.conf"); 设置文件/system/etc/dbus.conf的所有者为1002,所属用户组为1002,权限为:所有者有读权限,所属用户组有读权限,其他无任何权限。
- 复制代码
【语法】set_perm(<uid>,<gid>,<mode>, "<path>");
<uid>表示用户名称
<gid>表示用户组名称
<mode>表示权限模式
<path> 表示文件路径,可以使多个,用空格隔开
【作用】设置单个文件或目录的所有者和权限,像linux中的chmod、chown或chgrp命令一样,只是集中在了一个命令当中
【举例】set_perm(0,2000,0550,"system/etc/init.goldfish.sh")(设置手机system中的etc/init.goldfish.sh的用户为root,用户组为shell,所有者以及所属用户组成员可以进行读取和执行操作,其他用户无操作权限)
【说明】在此命令中最难明白的是0 2000 0550这几组参数所代表的意思,这是Linux相关的参数
具体如下: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 ××× (每个人都有读和写以及执行的权限)
范例 :
-rw------- (600) -- 只有用户有读写权限。
-rw-r--r-- (644) -- 只有用户有读写权限;而组用户和其他用户只有读权限。
-rwx------ (700) -- 只有用户有读、写、执行权限。
-rwxr-xr-x (755) -- 用户有读、写、执行权限;而组用户和其他用户只有读、执行权限。
-rwx--x--x (711) -- 用户有读、写、执行权限;而组用户和其他用户只有执行权限。
-rw-rw-rw- (666) -- 所有用户都有文件读、写权限。这种做法不可取。
-rwxrwxrwx (777) -- 所有用户都有读、写、执行权限。更不可取的做法。
- set_perm_recursive(...);设置文件夹和文件夹内文件的权限
- set_perm_recursive(1000, 1000, 0771, 0644, "/data/app"); 设置/data/app的所有者和所属用户组为1000,app文件夹的权限是:所有者和所属组拥有全部权限,其他有执行权限;
- app文件夹下的文件权限是:所有者有读写权限,所属组有读权限,其他有读权限。
- 复制代码
【语法】set_perm_recursive <uid> <gid> <dir-mode> <file-mode> <path> [...<pathN>]
<uid>表示用户,<gid>表示用户组,<dir-mode>表示文件夹的权限,<file-mode>表示文件的权限,<path> [... <pathN>]表示文件夹的路径,可以多个,用空格分开
【作用】设置文件夹及文件夹中的文件的所有者和用户组
【说明】其中<dir-mode> <file-mode>分别代表目录和file的权限,具体参数如上述
【举例】set_perm_recursive 0 0 0755 0644 SYSTEM:app(设置手机system/app文件夹及其中文件的用户为root,用户组为root,app文件夹权限为所有者可以进行读、写、执行操作,其他用户可以进行读取和执行操作,其中的文件的权限为所有者可以进行读写操作,其他用户可以进行读取操作)
下面是我们常用的两组修改权限的命令:
一组是常规程序用RE管理器拷贝到system/app后修改的权限命令如下:
set_perm(0,0,0644,"/system/app/Calendar.apk");
一组是我们要移动dalvik-cache到cache过程中拷贝修改mot_boot_mode.bin命令如下:
set_perm(0,0,0755,"/system/bin");
• ui_print("pwelyn");屏幕打印输出"pwelyn"
• ui_print("GR[GreatRom/GfanRom]"); 屏幕打印GR[GreatRom/GfanRom]
• 复制代码
• run_program();运行shell脚本
• run_program("/system/xbin/installbusybox.sh"); 运行installbusybox.sh脚本文件
• 复制代码
• write_raw_image(, partition);写入至partition分区
• write_raw_image("/tmp/boot.img", "boot")将boot.img直接写入boot分区
• 复制代码
• assert(...);如果执行sub1不返回错误则执行sub2,如果sub2不返回错误则执行sub3一次类推。
• 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
• 复制代码
• run_program("/sbin/sleep", "3");
• run_program("/sbin/reboot");