• 给第三方apk进行系统签名的几种方式【转】


    本文转载自:http://blog.csdn.net/luzhenrong45/article/details/47733053

     

    ----------------------------------------------------------------------------

     

    此文章仅作为学习交流所用
    转载或引用请务必注明原文地址:
    http://blog.csdn.net/luzhenrong45/article/details/47733053
    或联系作者:luzhenrong45@gmail.com
    谢谢!   

     

     

    ----------------------------------------------------------------------------

     

    注:本文假设你已经拥有Android系统源码,且对Android源码有一定认识。

     

    工作中有时会遇到一些apk签名不同,导致无法安装的问题。
        场景一:

        有一个第三方apk(具有系统权限),无法安装在我们自己的Android机器上,提示以下错误,导致无法安装。

        

        这是由于该APK具有系统权限,而系统签名与我们的Android设备系统签名不一致。Android检测到系统签名不一致,由于安全因素考虑,就阻止安装了。   

        解决方法:使用自己的Android签名工具给apk重新签名。

        (1) Android的签名文件存放于系统源码的 build/target/product/security/目录下

        
        该目录下有 media.pk8、media.x509.pem、platform.pk8、platform.x509.pem、shared.pk8、shared.x509.pem、testkey.pk8、testkey.x509.pem等签名文件,不同的签名文件,对应不同的权限。Android默认的签名文件为testkey.pk8、testkey.x509.pem。

        (2) Android自带的签名工具为 signapk.jar, 可以在源码编译目录out中找到,具体路径为:out/host/linux-x86/framework/signapk.jar    以上APK具有系统权限,重新签名应该使用platform签名文件进行签名。

        签名方法:将对应权限的签名文件platform.pk8、platform.x509.pem, 签名工具 signapk.jar, 以及需要签名的apk(假设 old.apk) 放到同一目录下,打开linux终端(windows cmd也可以),进入该目录,进行重新签名:

        java -jar signapk.jar platform.x509.pem platform.pk8 old.apk new.apk

        重新生成的new.apk就可以安装在我们的Android设备上了。

        

        场景二:具有apk源码,同样是具备系统权限的,当我们将apk源码导入Eclipse中,使用 Run as --> Android application 编译安装APK时, Eclise同样会提示场景一的错误信息,原因也是一样。我们同样可以将Eclipse生成的apk按照场景一的方法进行重新签名,再安装到我们的设备上。但是,有时可能我们会经常修改apk源码进行调试验证,如果每次都把apk拿出来进行重新签名,再安装,这样确实麻烦了一些。Eclipse是支持使用自己的系统签名工具进行APK打包签名的。使用这种方法,可以快速而方便地对APK进行系统签名,并将其安装到我们的Android设备上。下面说一下具体做法:

    步骤一:同样取源码目录build argetproductsecurity 目录下的platform.pk8 platform.x509.pem放到某一个目录下

    步骤二:进入该目录,生成shared.priv.pem

    openssl pkcs8 -in platform.pk8 -inform DER -outform PEM -out shared.priv.pem -nocrypt

    步骤三:生成pkcs12

    openssl pkcs12 -export -in platform.x509.pem -inkey shared.priv.pem -out shared.pk12 -name androiddebugkey

    Enter Export Password:
    Verifying - Enter Export Password:

    这里会提示输入密码,默认密码是android,如是自己制作的key,输入对应的密码。

    步骤四:生成debug.keystore,Eclipse需要使用该keystore.
    keytool -importkeystore -deststorepass android -destkeypass android -destkeystore debug.keystore -srckeystore shared.pk12 -srcstoretype PKCS12 -srcstorepass android -alias androiddebugkey

    步骤五:在Eclipse的  Windows/Preferences/Android/Build 中设置"Custom debug keystore"为刚才步骤四生成的debug.keystore即可直接run安装调试apk.这样的话,就可以不用再去用signapk.jar,如java -jar signapk.jar platform.x509.pem platform.pk8 *.apk **.apk进行签名了。


    注:场景二其实也可以直接将APK源码放在Android系统源码的环境下用make来编译,需要编写Android.mk,加入LOCAL_CERTIFICATE := platform,

    可以直接使用mm编译apk, 编译出来的APK同样可以顺利安装在我们自己的Android设备上。

    一个简单的Android.mk(APK源码只包含java文件,不含JNI代码)文件可以参考以下写法,其中 XXX 修改为你的apk名字。

    进入该源码目录,执行mm命令,即可在out/target/product/$PRODUCT_NAME/system/app目录下生成 xxx.apk

  • 相关阅读:
    类的继承,抽象类和接口
    什么是CGI、FastCGI、PHP-CGI、PHP-FPM、Spawn-FCGI?
    php 中 SERVER 服务器参数
    数组与对象互换方法
    php实现二维数组查找功能【array_search 和 array_column】
    php基础知识点列表【2020年10月7日】
    json_encode 中文及特殊斜杆的编码
    吴裕雄--天生自然ANDROID开发学习:2.5.8 Notification(状态栏通知)详解
    吴裕雄--天生自然ANDROID开发学习:2.5.7 Toast(吐司)的基本使用
    吴裕雄--天生自然ANDROID开发学习:2.5.6 ViewFlipper(翻转视图)的基本使用
  • 原文地址:https://www.cnblogs.com/zzb-Dream-90Time/p/8485465.html
Copyright © 2020-2023  润新知