可用于没有签名和已经签名的apk,再次签名。
jarsigner -verbose -keystore [keystorePath] -signedjar [apkOut] [apkin] [alias]
命令格式及参数意义:
-verbose -> 输出签名过程的详细信息
-keystore [keystorePath] -> 密钥的库的位置
-signedjar [apkOut] -> 签名后的输出文件名
[apkin] -> 待签名的文件名
[alias] -> 证书别名
示例:
D:\>jarsigner -verbose -keystore demo.keystore -signedjar jaq_demo_signed.apk jaq_demo.apk demo.keystore
下面为转载:https://blog.csdn.net/xys616/article/details/123892541
重打包签名后的 apk,在安装时报错:
Failure [-124: Failed parse during installPackageLI: Targeting R+ (version 30 and above) requires the resources.arsc of installed APKs to be stored uncompressed and aligned on a 4-byte boundary]
众所周知,apk 文件实质上是 zip 压缩格式,而在安卓 11 以上,apk 需要进行 4 字节对齐:https://developer.android.com/studio/command-line/zipalign
使用 Android Studio 进行构建,则此步骤会自动完成。重打包则需要手动完成。
安卓 sdk 提供了对齐工具 zipalign
zipalign 是一种 zip 归档文件对齐工具。它可确保归档中的所有未压缩文件相对于文件开头都是对齐的。这样一来,您便可直接通过 mmap(2) 访问这些文件,而无需在 RAM 中复制相关数据并减少了应用的内存用量。
如需对齐 infile.apk 并将其保存为 outfile.apk,请运行以下命令:
zipalign -p -f -v 4 infile.apk outfile.apk
如需确认 existing.apk 的对齐方式,请运行以下命令:
zipalign -c -v 4 existing.apk
对齐完成后不再使用 jarsigner 签名,而是用 apksigner。在 sdk/build-tools 中可以找到。
// apksigner sign --ks (签名地址) --ks-key-alias (别名) --out (签名后的apk地址) (待签名apk地址)
apksigner sign --ks platform.keystore --ks-key-alias androidpublishkey --out signed_source_v2_final.apk source_4KB_PBS.apk