Android中APK签名工具之jarsigner和apksigner详解

/ AndroidJava / 没有评论 / 2859浏览

一.工具介绍

不管是apk包,还是jar包,本质都是zip格式的压缩包,所以它们的签名过程都差不多(仅限V1签名),以上两个工具都可以对Android apk包进行签名.

1.V1和V2签名的区别

在Android Studio中点击菜单 Build->Generate signed apk... 打包签名过程中,可以看到两种签名选项 V1(Jar Signature) V2(Full APK Signature),刚开始升级AS看到这个懵了,既然是APK Signature,就放心偷懒选了V2,结果安装失败???无奈,只能查资料...

从Android 7.0开始, 谷歌增加新签名方案 V2 Scheme (APK Signature);但Android 7.0以下版本, 只能用旧签名方案 V1 scheme (JAR signing)

V1签名:

V2签名:

V2签名优点很明显:

注意: apksigner工具默认同时使用V1和V2签名,以兼容Android 7.0以下版本

2.zipalign和V2签名

位于Android SDK/build-tools/SDK版本/zipalign.exe。 zipalign 是对zip包对齐的工具,使APK包内未压缩的数据有序排列对齐,从而减少APP运行时内存消耗

zipalign -v 4 in.apk out.apk //4字节对齐优化
zipalign -c -v 4 in.apk  //检查APK是否对齐

zipalign可以在V1签名后执行,但zipalign不能在V2签名后执行,只能在V2签名之前执行!!!

二.签名步骤

1.生成密钥对(已有密钥库,可忽略)

Eclipse或Android Studio在Debug时,对App签名都会使用一个默认的密钥库:

1.生成密钥对

​ 进入JDK/bin, 输入命令

keytool -genkeypair -keystore 密钥库名 -alias 密钥别名 -validity 天数 -keyalg RSA

​ 参数:

​ -genkeypair 生成一条密钥对(由私钥和公钥组成) ​ -keystore 密钥库名字以及存储位置(默认当前目录) ​ -alias 密钥对的别名(密钥库可以存在多个密钥对,用于区分不同密钥对) ​ -validity 密钥对的有效期(单位: 天) ​ -keyalg 生成密钥对的算法(常用RSA/DSA,DSA只用于签名,默认采用DSA) ​ -delete 删除一条密钥

​ 提示: 可重复使用此条命令,在同一密钥库中创建多条密钥对

​ 例如: 在debug.keystore中新增一对密钥,别名是release

keytool -genkeypair -keystore debug.keystore -alias release -validity 30000

2.查看密钥库

​ 进入JDK/bin, 输入命令

keytool -list -v -keystore 密钥库名

​ 参数:

​ -list 查看密钥列表 ​ -v 查看密钥详情

​ 例如:

`keytool -list -v -keystore debug.keystore`

​ 现在debug.keystore密钥库中有两对密钥, 别名分别是androiddebugkey release

2.签名

1.方法一(jarsigner,只支持V1签名)

​ 进入JDK/bin, 输入命令jarsigner -keystore 密钥库名 xxx.apk 密钥别名

​ 从JDK7开始, jarsigner默认算法是SHA256, 但Android 4.2以下不支持该算法,

​ 所以需要修改算法, 添加参数 -digestalg SHA1 -sigalg SHA1withRSA

jarsigner -keystore 密钥库名 -digestalg SHA1 -sigalg SHA1withRSA xxx.apk 密钥别名

​ 参数:

​ -digestalg 摘要算法 ​ -sigalg 签名算法

​ 例如:

​ 用JDK7及以上jarsigner签名,不支持Android 4.2 以下

jarsigner -keystore debug.keystore MyApp.apk androiddebugkey

​ 用JDK7及以上jarsigner签名,兼容Android 4.2 以下

jarsigner -keystore debug.keystore -digestalg SHA1 -sigalg SHA1withRSA MyApp.apk androiddebugkey

2.方法二(apksigner,默认同时使用V1和V2签名)

​ 进入Android SDK/build-tools/SDK版本, 输入命令

​apksigner sign --ks 密钥库名 --ks-key-alias 密钥别名 xxx.apk

​ 若密钥库中有多个密钥对,则必须指定密钥别名

apksigner sign --ks 密钥库名 --ks-key-alias 密钥别名 xxx.apk

​ 禁用V2签名

apksigner sign --v2-signing-enabled false --ks 密钥库名 xxx.apk

​ 参数:

​ --ks-key-alias 密钥别名,若密钥库有一个密钥对,则可省略,反之必选 ​ --v1-signing-enabled 是否开启V1签名,默认开启 ​ --v2-signing-enabled 是否开启V2签名,默认开启

​ 例如:

​ 在debug.keystore密钥库只有一个密钥对

apksigner sign --ks debug.keystore MyApp.apk

​ 在debug.keystore密钥库中有多个密钥对,所以必须指定密钥别名

apksigner sign --ks debug.keystore --ks-key-alias androiddebugkey MyApp.apk

3.签名验证

1.方法一(keytool,只支持V1签名校验)

​ 进入JDK/bin, 输入命令

keytool -printcert -jarfile MyApp.apk (显示签名证书信息)

​ 参数:

​ -printcert 打印证书内容 ​ -jarfile 已签名的jar文件 或apk文件

2.方法二(apksigner,支持V1和V2签名校验)

​ 进入Android SDK/build-tools/SDK版本, 输入命令

apksigner verify -v --print-certs xxx.apk

​ 参数:

​ -v, --verbose 显示详情(显示是否使用V1和V2签名) ​ --print-certs 显示签名证书信息

​ 例如:

apksigner verify -v MyApp.apk

​ Verifies ​ Verified using v1 scheme (JAR signing): true ​ Verified using v2 scheme (APK Signature Scheme v2): true ​ Number of signers: 1

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。