我一直在尝试在android中制作一个自定义ROM。所以,我已经能够成功地在Nexus 4中进行更改和闪存。但我的主要目标是为我的ROM提供Ota更新。现在我可以用update.zip使用adb sideload更新设备,现在我希望它可以通过系统应用程序自动完成。为此,我制作了一个系统应用程序,可以从我的服务器上下载update.zip。 我已经通过这个环节去无任何进展: Android development RecoverySystem.installPackage() cannot write to /cache/recovery/command permission deniedAOSP太田更新
我已经使用的AsyncTask下面的代码来安装更新:
File update = new File("/data/update.zip");
try {
RecoverySystem.installPackage(mContext, update);
} catch (IOException e) {
e.printStackTrace();
}
但我收到以下错误:
W/RecoverySystem(3900): !!! REBOOTING TO INSTALL /data/update.zip !!!
W/System.err(3900): java.io.FileNotFoundException: /cache/recovery/command: open failed: ENOENT (No such file or directory)
W/System.err(3900): at libcore.io.IoBridge.open(IoBridge.java:456)
W/System.err(3900): at java.io.FileOutputStream.<init>(FileOutputStream.java:87)
W/System.err(3900): at java.io.FileOutputStream.<init>(FileOutputStream.java:72)
W/System.err(3900): at java.io.FileWriter.<init>(FileWriter.java:42)
W/System.err(3900): at android.os.RecoverySystem.bootCommand(RecoverySystem.java:454)
W/com.test.ota(3966): type=1400 audit(0.0:8): avc: denied { write } for comm=4173796E635461736B202331 name="/" dev="mmcblk0p22" ino=2 scontext=u:r:system_app:s0 tcontext=u:object_r:cache_file:s0 tclass=dir
我感到困惑的是我能够在下载时访问数据目录(这是普通应用程序无法访问的),但我无法访问/缓存。
我应该如何继续,以便在访问/缓存时不会拒绝系统应用程序的权限?
我的清单文件是:
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
android:sharedUserId="android.uid.system"
xmlns:tools="http://schemas.android.com/tools"
package="com.test.ota">
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.WRITE_SETTINGS" />
<uses-permission android:name="android.permission.ACCESS_SUPERUSER" />
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />
<uses-permission android:name="android.permission.WAKE_LOCK" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.VIBRATE" />
<uses-permission
android:name="android.permission.ACCESS_CACHE_FILESYSTEM"
tools:ignore="ProtectedPermissions"/>
<uses-permission
android:name="android.permission.DELETE_CACHE_FILES"
tools:ignore="ProtectedPermissions"/>
<uses-permission
android:name="android.permission.REBOOT"
tools:ignore="ProtectedPermissions" />
<uses-permission android:name="android.permission.RECOVERY" />
顺便说一句,我的体型分支是Android的5.1.1_r19
更新1: 我建立full_mako-userdebug。所以,当adb需要时我有su。在adb shell中,当我尝试在su后创建cache/recovery/command
时,它允许我创建文件。但通过应用程序,它不允许我在cache/recovery/
中创建文件,即使其系统应用程序。我不希望用户只是为了安装一个更新而为根。仍然有同样的问题。
是的,我检查了更新.zip存在。在我甚至尝试通过app手动创建'/ cache/recovery/command'之前。但是创建文件会给出相同的权限被拒绝的错误。 –