自学内容网 自学内容网

Android 用 platform.pk8 和 platform.x509.pem 生成 keystore 系统签名文件

一,背景介绍

        最近需要开发一个拥有系统级权限的应用,就了解了下系统应用的签名方式,这里来简单介绍下。

        在进行 Android 应用开发的时候,如果开发的是系统应用,那么就需要有系统签名才能正常运行,而系统应用一般是放到系统代码库中跟随系统一起编译。如果想要用 Android Studio 单独对某个开发的应用进行签名的话,有两种方式可以选择。一种方法是编译完成后使用 signApk.jar 、platform.pk8 和 platform.x509.pem 进行配合签名。第二种方法是把系统的 platform.pk8 和 platform.x509.pem 转换成为我们可以直接使用的 keystore 文件,在编译时自动签名。

        相对而言,第二种方法更为方便,可以全自动化对应用进行签名,方便开发人员测试。
这里介绍下第二种方式的实现方法。

二,生成keystore系统签名文件

2.1 转换pk8文件为pem

        cd到pk8以及x509.pem文件的目录执行如下命令,把platform.pk8生成了.pem 文件,/build/make/target/product/security,

执行脚本:

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

执行如下命令,生成pkcs12格式的密钥文件,生成platform.pk12文件,最后的android是keystore的alias,这里默认为android, platform.pk12是pk12文件名,需要输入两次密码(密码android),

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

执行如下命令生成keystore文件,

keytool -importkeystore -destkeystore platform.keystore -srckeystore platform.pk12 -srcstoretype PKCS12 -srcstorepass android -alias android

Android Studio的app/build.gradle中加入:
 

signingConfigs {
    debug {
        storeFile file('platform.keystore')
        storePassword "android"
        keyAlias "android"
        keyPassword "android"
    }
    release {
        storeFile file('platform.keystore')
        storePassword "android"
        keyAlias "android"
        keyPassword "android"
        v1SigningEnabled true
        v2SigningEnabled true
    }
}


原文地址:https://blog.csdn.net/allen_xu_2012_new/article/details/144029424

免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!