[APK签名] apksigner APK V2签名

apksigner V2签名

Android打渠道包时,经常先打一个母包,解压这个母包,完成渠道信息的注入后,需要对APK重新签名,这时就会用到jarsigner 或者 apksigner

打包涉及到两个签名工具 jarsignerapksigner,其对应的签名方案如下:

  • v1 方案:基于 JAR 签名,采用的签名工具为 jarsigner
  • v2 方案:APK 签名方案 v2,在 Android 7.0 引入,采用的签名工具为 apksigner
  • v3 方案:APK 签名方案v3,在 Android 9.0 引入,采用的签名工具为 apksigner

当前几乎所有的应用市场都要求采用V2以上签名方案,因此本文只介绍apksigner工具:

如果了解 jarsigner V1 签名打包,可参考:
jarsigner 对APK签名:
https://blog.csdn.net/xiaxl/article/details/118800585

apksigner 是Android SDK中的一个签名工具,该工具的文件路径一般为 sdk\build-tools\28.0.3\lib
该工具所在的文件路径:因V2签名方案,于Android 7.0版本引入,所以Android SDK中build-tools 24.0.3 以上版本的lib目录下才能找到apksigner.jar工具。
apksigner.jar路径

  • 使用.keystore签名文件
  • 使用.x509.pem、.pk8签名文件

一、使用.keystore签名文件

使用签名工具 apksigner 使用.keystore签名文件,对APK重新签名,使用方式如下:

// --ks [签名证书路径]
// --ks-key-alias [别名]
// --ks-pass pass:[KeyStore密码]
//  --key-pass pass:[签署者的密码]
//  --out [output.apk] [input.apk]

java -jar apksigner.jar sign --ks android.keystore --ks-key-alias cmccsdk --ks-pass pass:123456 --key-pass pass:123456 --out output.apk input.apk

验证APK对应的签名版本:

完成签名后,可以用以下命令查看APK采用的签名方案。

// 验证APK采用的是V1、V2 还是V3签名
apksigner verify -v test.apk

apksigner 重新签名

二、使用.x509.pem、.pk8签名文件

platform.x509.pem、platform.pk8 为Android系统的签名文件,因此使用platform.x509.pem、platform.pk8 为APK签名时,这个APK往往是系统APP

为系统APP签名,还有一种方案是:
platform.x509.pem、platform.pk8 签名文件 转化为 .keystore 签名文件,然后 一、采用.keystore签名文件重签名
.pk8、.x509.pem转化为.keystore签名 可参考:
https://blog.csdn.net/xiaxl/article/details/107056180

// 1.Linux平台签名
// 将 libconscrypt_openjdk_jni.so 拷贝当前目录 cp  prebuilts/sdk/tools/linux/lib64/libconscrypt_openjdk_jni.so 
// 将 signapk.jar 工具拷贝到当前目录

java -Djava.library.path=. -jar signapk.jar platform.x509.pem platform.pk8 input.apk
 output.apk
 
 
// 2.Mac平台签名
// 将 libconscrypt_openjdk_jni.dylib 拷贝当前目录 cp /prebuilts/sdk/tools/darwin/lib64/libconscrypt_openjdk_jni.dylib 
// 将 signapk.jar 工具拷贝到当前目录

java -Djava.library.path=. -jar signapk.jar platform.x509.pem platform.pk8 input.apk
 output.apk
  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在Android中,APK签名是一种用于验证应用程序的完整性和来源的安全机制。通过对APK文件进行签名,可以确保应用程序在安装和更新过程中没有被篡改或恶意修改。 Android支持多种应用签名方案,包括v1、v2、v3和v4方案。v1方案是基于JAR签名,是最早引入的签名方案。v2方案是在Android 7.0引入的APK签名方案,提供了更强的安全性和完整性保护。v3方案是在Android 9.0引入的APK签名方案,进一步增强了应用程序的安全性。v4方案是在Android 11.0引入的APK签名方案,提供了更多的功能和安全性。 要对APK进行签名,可以使用命令行工具或者使用Android开发工具包(SDK)提供的工具。一个常见的签名操作是使用Java命令行工具执行签名操作,具体命令如下: ``` java -jar signapk.jar platform.x509.pem platform.pk8 input.apk output.apk ``` 这个命令将使用指定的签名证书和私钥对输入的APK文件进行签名,并生成一个新的已签名APK文件。 通过对APK进行签名,应用程序将获得系统权限。具体的权限可以在AndroidManifest.xml文件中查看,该文件位于frameworks/base/core/res/目录下。如果将应用程序的签名预置到系统中,应用程序将具有更多的系统权限,而如果使用应用程序自身的签名,则只会具有普通权限。 总结起来,APK签名是一种用于验证应用程序完整性和来源的安全机制,在Android中支持多种签名方案。通过对APK进行签名,应用程序可以获得系统权限。 #### 引用[.reference_title] - *1* *3* [android apk 签名(平台和普通签名)](https://blog.csdn.net/topsecrethhh/article/details/103376745)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Android apk签名原理](https://blog.csdn.net/weixin_42600398/article/details/122843107)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

bjxiaxueliang

您的鼓励是我创作的最大动力!

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

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

打赏作者

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

抵扣说明:

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

余额充值