alibabamama 发表于 2019-1-28 07:20:46

安卓手机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 文件与目录的默认权限



页: [1]
查看完整版本: 安卓手机recovery下刷补丁提示:“can't open /sdcard/update.zip(bad)”