从Android源码中生成系统签名文件

从Android源码中生成系统签名文件

本文介绍如何从Android源码环境中生成签名文件。
注意,需要源码环境哦,window环境是会报错的!

生成和使用系统签名文件jks主要有下面几步:

1、在linux中打开编译android源码目录。

2、cd到签名文件位置


cd build/target/product/security/ 

3、生成 platform.pem文件

执行如下命令;

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

生成 platform.pem文件.

4、生成 platform.p12 文件

执行如下命令;

openssl pkcs12 -export -in platform.x509.pem -out platform.p12 -inkey platform.pem -password pass:skg202302 -name skg

生成 platform.p12 文件,其中huld 为 skg 名(app添加签名要用到),skg202302 为密码。

5、生成 最终的 platform.jks系统签名文件

执行如下命令;

 keytool -importkeystore -deststorepass skg202302 -destkeystore platform.jks -srckeystore platform.p12 -srcstoretype PKCS12 -srcstorepass skg202302

生成 platform.jks (app打签名最终用到的文件),其中-deststorepass skg202302 设置的是这个签名的密码,上面指令中的-src*的其他参数都是从前面两个指令中生成的。

正常成功执行的过程如下图所示:

在这里插入图片描述

对Android Studio 来说,上面的信息生成的签名文件,是包含如下信息的:

	storeFile file("./platform.jks") //签名文件路径,根目录
	storePassword "skg202302" //签名的密码
	keyAlias "skg" //账户名称
	keyPassword "skg202302" //账户密码

6、把platform.jks 放到Studio 项目app 根目录下

7、在对应需要签名的module(默认是app)的build.gradle中添加如下代码:

android {
    compileSdkVersion 30
    buildToolsVersion "30.0.0"
    compileOptions {
        sourceCompatibility JavaVersion.VERSION_1_8
        targetCompatibility JavaVersion.VERSION_1_8
    }
。。。
    //证书信息在这里配置
    signingConfigs {
        main {
            storeFile file("./platform.jks") //签名文件路径,根目录
            storePassword "skg202302"
            keyAlias "skg"
            keyPassword "skg202302"
        }
    }

    buildTypes {
        release {
            minifyEnabled false
            signingConfig signingConfigs.main //添加这一行
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
        debug {
            minifyEnabled false
            signingConfig signingConfigs.main //添加这一行
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }

}

其他:

在非源码环境生成签名文件会报错

生成签名文件的操作需要在linux 源码环境下,如果在window执行(需要配置openssl环境),最后一步会报错(不同版本的openssl可能出现的错误不同)。

E:\code\security>keytool -importkeystore -deststorepass skg202302 -destkeystore platform.jks -srckeystore platform.p12 -srcstoretype PKCS12 -srcstorepass skg202302
keytool 错误: java.io.IOException: parseAlgParameters failed: ObjectIdentifier() – data isn’t an object ID (tag = 48)

如果没执行source环境,可能也会报错


程序 'keytool' 已包含在下列软件包中:
 * gcj-4.8-jre-headless
 * openjdk-7-jre-headless
 * gcj-4.6-jre-headless
 * openjdk-6-jre-headless
请要求管理员安装其中的一个

这时输入java -version /which java 都是没用的!source之后就不会有这个问题!

无法生成签名文件?

有些系统环境的签名文件已经被修改、加密,是无法生成签名文件的,这个要问供应商才知道了。
比如我之前接触的华为手机源码,Android9和之前是可以的,之后的源码已经无法生成签名文件的。

猜你喜欢

转载自blog.csdn.net/wenzhi20102321/article/details/134898404