码迷,mamicode.com
首页 > 其他好文 > 详细

给第三方apk进行系统签名的几种方式

时间:2015-08-17 23:48:29      阅读:151      评论:0      收藏:0      [点我收藏+]

标签:linux   android   ubuntu   apk   

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


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

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


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

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

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

    技术分享


    这是由于供应商提供的APK是用他们的签名工具签名的,而我们的aDesk,是采用我们自己的系统签名工具的。供应商的APK安装在我们的aDesk上,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就可以安装在我们的aDesk瘦客户机上了。

    

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


步骤一:同样取源码目录build\target\product\security 目录下的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设备上。


版权声明:本文为博主原创文章,未经博主允许不得转载。

给第三方apk进行系统签名的几种方式

标签:linux   android   ubuntu   apk   

原文地址:http://blog.csdn.net/luzhenrong45/article/details/47733053

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!