• 层层剥开Android14升级后异常弹框的神秘面纱


    本篇文章将会通过研究源码的方式给您讲述Android系统升级到Android14后出现的两个异常弹框并给出消除它们的方案。闲话少叙,我们开始。

    问题描述

    在Android 14升级后,出现两个弹窗的异常情况。这里是异常的截图:

    接下来,我们对这两个异常弹框依次来分析。

    问题分析和解决方案

    由于两个异常弹框都是由系统主动弹出的,应用层面没有办法去干扰此流程。因此,要想分析这两个问题,我们只能通过系统源码找到弹框提示文字,进而找到对应的代码查看逻辑,分析源码进而找到解决方案。

    问题一

    通过搜索关键字 此应用与最新版 Android 不兼容。请检查是否有更新,或与应用开发者联系。,我们能够搜索到在Framework层的字符串资源文件中name为 deprecated_abi_message对应的字符串就是我们搜索的关键字。

    接下来我们通过namedeprecated_abi_message继续搜索,可以找到该字符串在系统中只在一个地方使用了,以下是它使用的代码:

    class DeprecatedAbiDialog extends AppWarnings.BaseDialog {
        //省略无关代码...
        final CharSequence message = context.getString(R.string.deprecated_abi_message);
    
        final AlertDialog.Builder builder = new AlertDialog.Builder(context)
                .setPositiveButton(R.string.ok, (dialog, which) ->
                        manager.setPackageFlag(
                                mPackageName, AppWarnings.FLAG_HIDE_DEPRECATED_ABI, true))
                .setMessage(message)
                .setTitle(label);
    //省略无关代码...
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    很清楚的可以看到这个字符串被使用创建成了一个AppWarnings.BaseDialog类型的弹框。离目标代码很近了,我们继续顺着源码找到DeprecatedAbiDialog类在哪里被调用以及它被调用的逻辑是什么。

    通过搜索我们可以找到以下调用:

    最终我们可以看到弹框的调用逻辑如下:

    public void showDeprecatedAbiDialogIfNeeded(ActivityRecord r) {
    //省略无关代码...
              if (is64BitDevice && appContainsOnly32bitLibraries) {
                  mUiHandler.showDeprecatedAbiDialog(r);
              }
          }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    自此我们终于找到了问题1异常弹框的触发逻辑。如果设备为64位指令集并且当前应用仅仅包含32位指令集的包,那么就会弹出问题1的异常弹框。

    问题一解决方案

    通过对问题1的分析,我们知道如果碰到该提示。我们的问题解决方案是 在项目的build.gradel文件的ndk部分添加arm64-v8a的指令集

    问题二

    分析步骤和问题1一致,我们最终可以找到以下代码:

       /**
          * Shows the "deprecated target sdk" warning, if necessary.
          *
          * @param r activity record for which the warning may be displayed
          */
         public void showDeprecatedTargetDialogIfNeeded(ActivityRecord r) {
             if (r.info.applicationInfo.targetSdkVersion < Build.VERSION.MIN_SUPPORTED_TARGET_SDK_INT) {
                 mUiHandler.showDeprecatedTargetDialog(r);
             }
         }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    当应用设置的targetSdkVersion值大于系统的常量 Build.VERSION.MIN_SUPPORTED_TARGET_SDK_INT会被触发。

    问题二解决方案

    通过源码的层层跳转,我们最终可以找到安卓14系统的Build.VERSION.MIN_SUPPORTED_TARGET_SDK_INT值为28。因此当要解决问题2,我们设置targetSdkVersion最少为29就能在安卓14上避免异常弹框。

    总结

    通过从源代码的角度分析安卓 14升级后出现双弹窗异常的原因,并根据调查结果提出解决方案,可以更好地定位问题并实施有效的修复措施。这种方法需要对系统和应用程序的源代码进行深入的检查和理解,并确保修复后的应用程序在新系统上能够正常运行。

    Android 学习笔录

    Android 性能优化篇:https://qr18.cn/FVlo89
    Android Framework底层原理篇:https://qr18.cn/AQpN4J
    Android 车载篇:https://qr18.cn/F05ZCM
    Android 逆向安全学习笔记:https://qr18.cn/CQ5TcL
    Android 音视频篇:https://qr18.cn/Ei3VPD
    Jetpack全家桶篇(内含Compose):https://qr18.cn/A0gajp
    OkHttp 源码解析笔记:https://qr18.cn/Cw0pBD
    Kotlin 篇:https://qr18.cn/CdjtAF
    Gradle 篇:https://qr18.cn/DzrmMB
    Flutter 篇:https://qr18.cn/DIvKma
    Android 八大知识体:https://qr18.cn/CyxarU
    Android 核心笔记:https://qr21.cn/CaZQLo
    Android 往年面试题锦:https://qr18.cn/CKV8OZ
    2023年最新Android 面试题集:https://qr18.cn/CgxrRy
    Android 车载开发岗位面试习题:https://qr18.cn/FTlyCJ
    音视频面试题锦:https://qr18.cn/AcV6Ap

  • 相关阅读:
    【Flutter】 Flutter Material Design 3 组件使用示例 1 FAB/Icon button/Segmented button/Badge/Progress
    Java程序员进阶全过程
    C# 进程和窗体句柄踩坑笔记
    “不要用 Edge 默认的必应,我被骗了”
    计算机毕业设计Java校园生活信息服务平台(源码+系统+mysql数据库+Lw文档)
    如何快速使用Vue3在electron项目开发chrome Devtools插件
    数据还可以刷新但是显示不到页面上了
    由Arrays.sort()引出的重载学习
    基于ResNet框架的CNN
    【Redis】Redis在Linux与windows上的安装&基本操作语法
  • 原文地址:https://blog.csdn.net/maniuT/article/details/134536070