关闭

Android 4.0.4系统在线升级实现过程中的一些问题总结

643人阅读 评论(0) 收藏 举报
分类:
最近有个项目需要自己实现系统升级功能,于是调查了一番,发现网上资料不少,但是比较混乱,花了好一番功夫才实现了这个功能,这里记录一下这个过程中遇到的问题,希望对以后需要自己做系统升级的兄弟姐妹们有所帮助。

       总的来说,代码是比较简单的,如果你只是要升级,那么调用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签名机制

 其他一些可供参考的资源:

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:1035300次
    • 积分:9344
    • 等级:
    • 排名:第1944名
    • 原创:31篇
    • 转载:369篇
    • 译文:1篇
    • 评论:139条
    最新评论