从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和之前是可以的,之后的源码已经无法生成签名文件的。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!