Android App打包加固后的APK无法安装问题

发布时间:2024年01月10日

最近开发的一个应用要上架,正常流程打完包后去加固,由于以前一直用的是360的加固助手,这里开始也是选择用它。

使用360加固:

问题一、开始出现的问题是说应用未签名无法加固,我明明是签名后打的包,怎么会没签名呢?后面使用? java -jar apksigner.jar verify -v apk地址? ?命令查看发现是没有进行V1签名,而360加固要求有v1,一查之下发现是Android6.0之前用V1,Android7.0之后用V2,把自己项目的支持最低版本改为23以下,重新打包发360发现可以加固了。

问题二、加固完后的APK发现无法安装。查了一下资料说啥的都有,最后发现一个靠谱的,是要进行再次签名处理,说是经过加固后可能会破坏掉签名。下面重点记录一下重新签名:

原理 (使用AndroidSdk 自带的apksigner.jar 文件进行签名, apksigner.jar文件在Android? SDK 的安装路径下,大致如此:{D:\Program Files}\Android\Sdk\build-tools\X.X.X\lib)在任意版本下都有该文件。

准备工作:

先进入apksigner.jar文件所在的路径:我的就是D:\Program Files\Android\Sdk\build-tools\30.0.3\lib

1、先查一下加固后的APK是否有进行签名

输入命令:java -jar apksigner.jar verify -v apk地址

java -jar apksigner.jar verify -v D:\test\app-release_100_jiagu.apk

DOES NOT VERIFY
ERROR: Missing META-INF/MANIFEST.MF

出现上图说明没有签名,其实加固前是有签名的,只是加固后被破坏了,这就需要进行再次签名。

2、使用如下命令签名

java -jar apksigner.jar sign --ks [签名文件路径] --ks-key-alias [alias的别名] --ks-pass pass:[密码] --key-pass pass:[密码] --out [签名后的新安装包路径] [待签名的安装包路径,即是加固后的安装包路径]

java -jar apksigner.jar sign --ks D:\myproject\test\XXX.jks --ks-key-alias XXX --ks-pass pass:XXX --key-pass pass:XXX --out D:\myproject\test\app-sign.apk D:\test\app-release_100_jiagu.apk

执行成功不会有信息提示,可以去输出路径下查看是否有包,我的如下:

提醒:这个语句太长,建议要细心一点,出问题时检查是否语句输错了,我就是这样,错了几次发现都是语句输错了。

3、去验证签名后的APK是否签名,重复1的语句,只是APK变成了2签名后的

java -jar apksigner.jar verify -v D:\myproject\test\app-sign.apk

这是就是签名成功了,然后就可以愉快的安装了。

如果不想降低自己的项目Android版本,可以使用腾讯加固。

文章来源:https://blog.csdn.net/qq_34707150/article/details/135514510
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。