Android apk签名(二)

发布应用之前,需要加固、打渠道包。而使用梆梆加固 和 360加固后,发现已签名的apk的签名掉了,这时就需要我们对apk进行二次签名。当然,项目中使用了一个打包工具,可以对加固后的apk同时进行签名 和 多渠道打包。(ProtectedApkResignerForWalle-master)

这里不讲工具,只讲如何对已有的apk进行签名验证。

之前介绍过一种方法如何对apk进行签名认证。

jarsigner -keystore 密钥库名 xxx.apk 密钥别名

上面这个命令支持签名,但是只支持v1签名,而且要想兼容低版本还需要修改算法,比较麻烦。所以,这里再介绍一种方法。

首先,在android studio中Build--->Generate Signed APK...

 

接着,选择对应的keystore进行签名,即可打出我们需要的带签名的apk。

然后,对该apk进行加固,但是加固后的apk文件签名掉了,也就是说需要对加固后的apk进行二次签名,否则不能正常安装。

Android sdk中提供了命令apksigner可以对apk进行签名(默认同时使用V1和V2签名)

这个命令存在于sdk的build-tools文件夹

 

这么多版本,从中选择一个点进去即可

如上图所示,可以看到apksigner.bat命令。

下面,我选择一个本地的一个apk文件:app_v1.0.apk

先对其进行签名验证,看其是否已签名。如果未签名,对其签名,最后再次验证签名。

(其实最简单的验证签名的方法就是安装这个apk,因为未签名的apk是无法安装的,这里我们使用命令来操作)

1.签名验证

备注:(keytool -printcert -jarfile xxx.apk 这种方式可以验证签名,但是只支持v1签名校验

命令:apksigner verify -v --print-certs apk完整路径

首先,要使用这个命令,我们需要在dos控制台进入这个目录

然后,使用: apksigner verify -v --print-certs C:\seven\app_v1.0.apk

可以看到,这时的apk未签名。

2.签名

命令:apksigner sign --ks 密钥库名 --ks-key-alias 密钥别名 apk完整路径

在控制台使用命令:

apksigner sign --ks C:\seven\keystore\daihoubang.keystore --ks-key-alias daihoubang C:\seven\app_v1.0.apk

回车,会提示输入keystore密码

输入密码回车后

这时的apk已经被签名了。(从修改日期也可以看出来,时间变了,说明apk被修改过)

3.再次验证签名

可以发现此时的apk已经签名了。然后就可以成功安装这个apk了。

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 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
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值