安卓手机recovery下刷补丁提示:“can't open /sdcard/update.zip(bad)”

网上很多说是SD卡有问题,什么格式化拉,换卡拉,还有说补丁包有问题,不要用下载工具下,用浏览器直接下载,等等等等……

哎,解决这个问题花了一天的时间,起初认为是刷机脚本问题,改了又改,无效。又以为是文件权限设置问题,改了又改,还是无效,

其实出现这个提示的原因就是:补丁包中的文件名不能有中文!!!空格是可以有的,中文是不能有的,忘了aapt也不识别中文么?

 

不过总算没白折腾,通过不断的网上搜索,也学到了很多知识。

 

关于权限

set_perm_recursive(1002, 1002, 0755, 0440, "/system/etc/bluetooth");
set_perm(0, 0, 0755, "/system/etc/bluetooth");

先是设置bluetooth目录和文件的UID1002,GID1002,目录权限0755,其下文件权限0440,

再设置bluetooth目录的UID0,GID0,权限0755

分为两行来写,为设定目录下文件用了第一行,又为了设目录本身用了第二行。set_perm原来是可以设定目录权限的,以前一直以为只能用于文件。

 

关于创建新文件的默认权限

很多刷机补丁的脚本里用了package_extract_dir,但并未用set_perm设置权限,那么未设置权限的文件的权限到底是怎么规定的呢?

recovery模式建立新文件,算是root账户

一、默认权限:
1:文件的默认权限为:666 rw- rw- rw-
2:目录的默认权限为:777 rwx rwx rwx

二、umask:
默认root的umask值为:0022,所以新创建的文件权限为:644,目录权限为:755
其它帐户的umask值为:0002,所以新创建的文件权限为:664,目录权限为:775

这就是为什么刷机包刷进文件,不设权限也可以的原因了,因为默认建立的权限正是我们所熟悉的(0,0,0755,0644)。当然这是对一般文件,特殊文件如su还是要设置权限的。

参考:

Linux文件默认权限:umask

Linux文件与目录的默认权限及隐藏权限

Linux 文件与目录的默认权限


原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://yiyangde7.blog.51cto.com/392692/1092809

你可能感兴趣的:(CCNA,bad,Recovery,recovery,刷机,权限,补丁)