Android APK打包 + APK签名

前言
Android APK 签名是一种数字签名机制,用于验证应用程序的完整性和身份。每个Android应用都必须被签名,以便Google Play Store和其他应用商店可以验证应用的身份和完整性。同时,签名还可以确保应用程序在更新过程中不会被篡改。

一、AndroidStudio内部打包方式

1)在 Android Studio 中打开项目,然后单击菜单栏中的 Build -> Generate Signed Bundle/APK。
请添加图片描述
2)在弹出的窗口中,选择“APK”选项并单击“Next”。
请添加图片描述
3)在下一个窗口中,选择“Create new…”,在“New Key Store”窗口中,输入“Key store path”、“Key store password”、“Key alias”、“Key password”等信息,然后单击“OK”,选项并单击“Next”。
请添加图片描述
4)在下一个窗口中,选择构建类型、签名版本并输入所需的信息,然后单击“Create”。构建 APK 文件并在指定的目录中生成签名文件。请添加图片描述
总结:需要注意的是,在生成签名文件时,请务必牢记密钥库文件的密码和别名的密码,以确保在以后的构建中能够使用正确的签名文件。

二、使用 apksigner.jar 签名

apksigner.jar:文件目录C:\Android\Sdk\build-tools\30.0.3\lib,24.0.3及更高版本才会有这个jar工具,这里选择使用29.0.2版本的签名工具。Android[7.0-9.0)版本,会默认签v1、v2签名。Android9.0版本及以上会默认签v1、v2、v3签名。

签名指令

java -jar C:\Android\Sdk\build-tools\30.0.3\lib\apksigner.jar sign --ks  keystoreFileAbsolutePath --ks-key-alias AliasName --v1-signing-enabled state  --v2-signing-enabled state apkAbsolutePath

keystoreFileAbsolutePath 为签名文件的绝对路径
AliasName 为指定签名文件的别名
state 为V1,V2签名状态
apkAbsolutePath 为APK文件的绝对路径

签名验证

java -jar C:\Android\Sdk\build-tools\30.0.3\lib\apksigner.jar verify --print-certs apkAbsolutePath

apkAbsolutePath 为APK文件的绝对路径
执行此命令后,你将能够查看与 APK 文件关联的签名证书信息,以确认签名是否成功。如果没有错误消息,而且你能够看到与密钥库中的证书匹配的信息,那么签名就是成功的。

总结:
需要注意的是,在生成签名文件时,请务必牢记密钥库文件的密码和别名的密码,以确保在以后的构建中能够使用正确的签名文件。
在发布应用程序时,请确保使用正确的签名文件来进行签名。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
1) APKtool软件包 及签名tool APKtool软件包有2个程序组成:apktool.jar 和 aapt.exe 另外提供一个批处理文件:apktool.bat,其内容为: java -jar "%~dp0\apktool.jar" %1 %2 %3 %4 %5 %6 %7 %8 %9 运行apktools.jar需要java环境(1.6.0版本以上)。 apktool.jar用于解包,apktool.jar和aapt.exe联合用于打包。 signapk.jar 用于签名。 2) APK文件的解包 下面以解开Contacts.apk为例。首先把Contacts.apk Copy到当前工作目录下(例:Test)。在DOS下打入命令 apktool d Contacts.apk ABC 这里“d”表示要解码。Contacts.apk是要解包的APK文件。ABC是子目录名。所有解包的文件都会放在这个子目录内。 3) APK文件的打包 在DOS下打入命令 apktool b ABC New-Contacts.apk 这里“b”表示要打包 ABC是子目录名,是解包时产生的子目录,用来存放所有解包后的和修改后的文件。 New-Contacts.apk打包后产生的新的APK文件。 4) 签名,不签名安装时可能提示如下错误: Failure [INSTALL_PARSE_FAILED_NO_CERTIFICATES] --- 没有签名,可以尝试test证书;签名方法见下面。 Failure [INSTALL_PARSE_FAILED_INCONSISTENT_CERTIFICATES] ---- 已存在签名,但使用证书不对,可以尝试使用其他证书签名签名方法:到目录android\build\target\product\security找到证书文件,这里可能会有几种证书,test/shared/platform/media,各种证书使用场景不同,可以自己google一下,因为签名很快而且可任意后续更改签名,可以自己尝试各种不同签名; 这个命令行是使用test证书的例子:java -jar signapk.jar testkey.x509.pem testkey.pk8 YOURAPK.apk YOURAPK_signed.apk YOURAPK_signed.apk就是签完名的apk,去测试一下您重新打包apk吧。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Android程序Su

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值