总的来说,代码是比较简单的,如果你只是要升级,那么调用RecoverySystem.installPackage()这个函数就行了。如果还想验证升级包的正确性,那就要在RecoverySystem.installPackage()之前调用一下RecoverySystem.verifyPackage()这个函数。
那么问题在哪里呢?
- 升级包的位置。升级包需要放在/cache目录下;
- 权限。需要在AndroidManifest.xml里添加
<uses-permission android:name="android.permission.ACCESS_CACHE_FILESYSTEM" />和
<uses-permission android:name="android.permission.REBOOT" />权限,
网上有人说需要添加<uses-permission android:name="android.permission.DELETE_CACHE_FILES" />,这其实是不需要的;
- 不需要android:sharedUserId="android.uid.system"。系统升级不需要system用户权限,而且加上这个之后,你会发现无法访问/mnt/sdcard下的文件了,即使加上
<uses-permission android:name="android.permission.WRITE_MEDIA_STORAGE" />,
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />和
<uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS" />权限
- 需要系统签名。apk出来后,需要系统签名。要签名一个没有签名过的APK,可以使用一个叫作Auto-sign的工具。Auto-sign工具实际运行的是一个叫做Sign.bat的批处理命令。用文本编辑器打开这个批处理文件,我们可以发现,实现签名功能的命令主要是这一行命令:
java -jar signapk.jar testkey.x509.pem testkey.pk8 update.apk update_signed.apk
这条命令的意义是:通过signapk.jar这个可执行jar包,以“testkey.x509.pem”这个公钥文件和“testkey.pk8”这个私钥文件对“update.apk”进行签名,签名后的文件保存为“update_signed.apk”。关于签名的详细介绍,请参见《Android签名机制》
其他一些可供参考的资源: