ADB安装包失败(apk install failed)问题记录_ADB

ADB简介

ADB,Android Debug Bridge 也称做调试桥。按照android官方文档的说法:

Android 调试桥 (adb) 是一种功能多样的命令行工具,可让您与设备进行通信。adb 命令可用于执行各种设备操作,例如安装和调试应用。adb 提供对 Unix shell(可用来在设备上运行各种命令)的访问权限。

adb 包含在 Android SDK 平台工具软件包中。你可以使用 SDK 管理器下载此软件包,该管理器会将其安装在 android_sdk/platform-tools/ 下。

ADB就是个Android程序开发和调试的一个强大工具,该工具提供了许多功能,例如连接设备/模拟器、查看日志、模拟输入、截屏等,甚至还有一些刷机相关的功能。

本文暂不讨论以上这些,就说下工作中遇到的关于apk/aab安装失败的问题吧。

ADB安装命令

apk安装的命令是:

adb install [-lrtsdg] <path_to_apk>

其中 adb install 后可以添加一些可选的参数来控制安装APK的行为,具体参数如下:

参数

含义

-l

将应用安装到保护目录 /mnt/asec

-r

允许覆盖安装

-t

允许安装 AndroidManifest.xml 里 application 指定 android:testOnly="true" 的应用

-s

将应用安装到 sdcard

-d

允许降级覆盖安装

-g

授予所有运行时权限

--abi abi-identifier

为特定 ABI 强制安装 apk,abi-identifier 可以是 armeabi-v7a、arm64-v8a、v86、x86_64 等

运行命令后如果见到Success代表安装成功。

ADB安装包失败(apk install failed)问题记录_Android反编译_02


安装失败

安装失败后会有错误输出,根据这些输出可以参考下面表格提供的解决方法来处理:

输出

含义

解决办法

INSTALL_FAILED_ALREADY_EXISTS

应用已经存在,或卸载了但没卸载干净

adb install 时使用 -r 参数,或者先 adb uninstall <packagename> 再安装

INSTALL_FAILED_INVALID_APK

无效的 APK 文件

INSTALL_FAILED_INVALID_URI

无效的 APK 文件名

确保 APK 文件名里无中文

INSTALL_FAILED_INSUFFICIENT_STORAGE

空间不足

清理空间

INSTALL_FAILED_DUPLICATE_PACKAGE

已经存在同名程序

INSTALL_FAILED_NO_SHARED_USER

请求的共享用户不存在

INSTALL_FAILED_UPDATE_INCOMPATIBLE

以前安装过同名应用,但卸载时数据没有移除;或者已安装该应用,但签名不一致

先 adb uninstall <packagename> 再安装

INSTALL_FAILED_SHARED_USER_INCOMPATIBLE

请求的共享用户存在但签名不一致

INSTALL_FAILED_MISSING_SHARED_LIBRARY

安装包使用了设备上不可用的共享库

INSTALL_FAILED_REPLACE_COULDNT_DELETE

替换时无法删除

INSTALL_FAILED_DEXOPT

dex 优化验证失败或空间不足

INSTALL_FAILED_OLDER_SDK

设备系统版本低于应用要求

INSTALL_FAILED_CONFLICTING_PROVIDER

设备里已经存在与应用里同名的 content provider

INSTALL_FAILED_NEWER_SDK

设备系统版本高于应用要求

INSTALL_FAILED_TEST_ONLY

应用是 test-only 的,但安装时没有指定 -t 参数

INSTALL_FAILED_CPU_ABI_INCOMPATIBLE

包含不兼容设备 CPU 应用程序二进制接口的 native code

INSTALL_FAILED_MISSING_FEATURE

应用使用了设备不可用的功能

INSTALL_FAILED_CONTAINER_ERROR

1. sdcard 访问失败;

2. 应用签名与 ROM 签名一致,被当作内置应用。

1. 确认 sdcard 可用,或者安装到内置存储;

2. 打包时不与 ROM 使用相同签名。

INSTALL_FAILED_INVALID_INSTALL_LOCATION

1. 不能安装到指定位置;

2. 应用签名与 ROM 签名一致,被当作内置应用。

1. 切换安装位置,添加或删除 -s 参数;

2. 打包时不与 ROM 使用相同签名。

INSTALL_FAILED_MEDIA_UNAVAILABLE

安装位置不可用

一般为 sdcard,确认 sdcard 可用或安装到内置存储

INSTALL_FAILED_VERIFICATION_TIMEOUT

验证安装包超时

INSTALL_FAILED_VERIFICATION_FAILURE

验证安装包失败

INSTALL_FAILED_PACKAGE_CHANGED

应用与调用程序期望的不一致


INSTALL_FAILED_UID_CHANGED

以前安装过该应用,与本次分配的 UID 不一致

清除以前安装过的残留文件

INSTALL_FAILED_VERSION_DOWNGRADE

已经安装了该应用更高版本

使用 -d 参数

INSTALL_FAILED_PERMISSION_MODEL_DOWNGRADE

已安装 target SDK 支持运行时权限的同名应用,要安装的版本不支持运行时权限

INSTALL_PARSE_FAILED_NOT_APK

指定路径不是文件,或不是以 .apk 结尾

INSTALL_PARSE_FAILED_BAD_MANIFEST

无法解析的 AndroidManifest.xml 文件

INSTALL_PARSE_FAILED_UNEXPECTED_EXCEPTION

解析器遇到异常

INSTALL_PARSE_FAILED_NO_CERTIFICATES

安装包没有签名

INSTALL_PARSE_FAILED_INCONSISTENT_CERTIFICATES

已安装该应用,且签名与 APK 文件不一致

先卸载设备上的该应用,再安装

INSTALL_PARSE_FAILED_CERTIFICATE_ENCODING

解析 APK 文件时遇到 CertificateEncodingException

INSTALL_PARSE_FAILED_BAD_PACKAGE_NAME

manifest 文件里没有或者使用了无效的包名

INSTALL_PARSE_FAILED_BAD_SHARED_USER_ID

manifest 文件里指定了无效的共享用户 ID

INSTALL_PARSE_FAILED_MANIFEST_MALFORMED

解析 manifest 文件时遇到结构性错误

INSTALL_PARSE_FAILED_MANIFEST_EMPTY

在 manifest 文件里找不到找可操作标签(instrumentation 或 application)

INSTALL_FAILED_INTERNAL_ERROR

因系统问题安装失败

INSTALL_FAILED_USER_RESTRICTED

用户被限制安装应用

在开发者选项里将「USB安装」打开,如果已经打开了,那先关闭再打开。

INSTALL_FAILED_DUPLICATE_PERMISSION

应用尝试定义一个已经存在的权限名称

INSTALL_FAILED_NO_MATCHING_ABIS

应用包含设备的应用程序二进制接口不支持的 native code

INSTALL_CANCELED_BY_USER

应用安装需要在设备上确认,但未操作设备或点了取消

在设备上同意安装

INSTALL_FAILED_ACWF_INCOMPATIBLE

应用程序与设备不兼容

INSTALL_FAILED_TEST_ONLY

APK 文件是使用 Android Studio 直接 RUN 编译出来的文件

通过 Gradle 的 assembleDebug 或 assembleRelease 重新编译,或者 Generate Signed APK

INSTALL_FAILED_ABORTED: User rejected permissions

应用安装有风险提示需要用户在设备上确认,但用户未操作设备或点了取消

在设备上同意安装

does not contain AndroidManifest.xml

无效的 APK 文件

is not a valid zip file

无效的 APK 文件

Offline

设备未连接成功

先将设备与 adb 连接成功

unauthorized

设备未授权允许调试

error: device not found

没有连接成功的设备

先将设备与 adb 连接成功

protocol failure

设备已断开连接

先将设备与 adb 连接成功

Unknown option: -s

Android 2.2 以下不支持安装到 sdcard

不使用 -s 参数

No space left on device

空间不足

清理空间

Permission denied ... sdcard ...

sdcard 不可用

signatures do not match the previously installed version; ignoring!

已安装该应用且签名不一致

先卸载设备上的该应用,再安装


实际问题以及解决方案

以上表格可以参考,但是有些情况还是需要根据实际遇到的问题来做针对性处理。

比如我本人遇到了以下几个报错:

  • adb: failed to install F:\Temp\muzi_signed.apk: Failure [INSTALL_FAILED_INVALID_APK: Failed to extract native libraries, res=-2]

Failed to extract native libraries 这个报错主要是源于AndroidManifest的application节点出现了extraNativeLibs属性,解决办法也很简单,去掉即可 android:extraNativeLibs=”false”,或者如上,改成true。

<application android:allowBackup="false" 
             android:appComponentFactory="android.support.v4.app.CoreComponentFactory" 
             android:extractNativeLibs="true"
             android:icon="@mipmap/app_icon" 
             android:label="@string/app_name" 
             android:name="com.u8.sdk.U8Application"
             android:roundIcon="@mipmap/app_icon_round" 
             android:supportsRtl="true">
... ...
</application>
  • adb: failed to install F:\Temp\muzi_signed.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]

翻译一下就是:如果以 Android 11(API 级别 30)或更高版本为目标平台的应用包含压缩的 resources.arsc 文件或者如果此文件未按 4 字节边界对齐,应用将无法安装。

解决办法有二:1. targetSdkVersion降级到30以下;2.在重新签名前对apk先进行对齐(使用Sdk\build-tools下的zipalign工具,具体可以看这个博客 [百分之五的坏的博客

  • adb: failed to install app-debug.apk: Failure [-127: Package 包名 attempting to declare permission 包名.andpermission.bridge in non-existing group 包名.andpermission]

无法安装应用,缺失权限组manifests里加上:

<permission-group android:name="${applicationId}.andpermission"/>

以上就是我在实际遇到的问题以及处理方式,后续如遇到更多也会加以补充。


参考资料