当前位置: 首页 > news >正文

.aar中申请权限时使用了android:maxSdkVersion导致主App的权限组找不到对应的权限

问题描述:

App集成了第三方的.aar包,.aar包中申请了定位权限,并且使用了 android:maxSdkVersion 属性;

<uses-permissionandroid:name="android.permission.ACCESS_COARSE_LOCATION"android:maxSdkVersion="30" />
<uses-permissionandroid:name="android.permission.ACCESS_FINE_LOCATION"android:maxSdkVersion="30" />

即使我的App中,已重新声明定位权限:

 <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" /><uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />

但是,当App运行时(Android 33),使用 PermissionX 动态申请权限时,发现 我的App系统的权限组映射里没有找到 ACCESS_FINE_LOCATION 和 ACCESS_COARSE_LOCATION 权限;

分析:

  • 第三方aar中声明的权限带有 maxSdkVersion=“30”,意味着这些权限仅在 API 30 及以下生效。 当你的应用运行在
  • API 33 时,系统会认为这两个权限已被“废弃”,从而不再将其加入权限组。

解决方法:

在我的App中,这样 重新声明定位权限:

使用 tools:node=“replace” 强制保留权限并移除 maxSdkVersion 限制:

<uses-permission-sdk-23 android:name="android.permission.ACCESS_COARSE_LOCATION"  tools:node="replace"/>
<uses-permission-sdk-23 android:name="android.permission.ACCESS_FINE_LOCATION"  tools:node="replace"/>

或者:

<uses-permission-sdk-23 android:name="android.permission.ACCESS_COARSE_LOCATION" />
<uses-permission-sdk-23 android:name="android.permission.ACCESS_FINE_LOCATION" />

相关文章:

  • 数据结构强化篇
  • SKLearn - Biclustering
  • pytorch学习使用
  • Android——RecyclerView
  • 时空特征如何融合?LSTM+Resnet有奇效,SOTA方案预测准确率超91%
  • C语言-- 深入理解指针(4)
  • 项目班——0422——日志
  • 微调灾情分析报告生成模型
  • 安卓触摸事件分发机制分析
  • Diamond软件的使用--(6)访问FPGA的专用SPI接口
  • 基于STM32、HAL库的AD7616BSTZ模数转换器ADC驱动程序设计
  • C++ - 类和对象 # 类的定义 #访问限定符 #类域 #实例化 #this 指针 #C++ 与 C语言的比较
  • 《代码整洁之道》第4章 注释 - 笔记
  • CentOS7.9安装OpenSSL 1.1.1t和OpenSSH9.9p1
  • 小结:BFD
  • Redis ssd是什么?Redis 内存空间优化的点都有哪些?embstr 和 row、intset、ziplist分别是什么?
  • LeetCode题解1297. 子串的最大出现次数
  • 大模型评测调研报告
  • 计算机网络 | 应用层(6) -- 套接字编程
  • 大模型基础(三):Llama3复现
  • 国家发改委:建立实施育儿补贴制度
  • 一张老照片里蕴含的上海文脉
  • 下任美联储主席热门人选沃什:美联储犯下“系统性错误”,未能控制一代人以来最严重的通胀
  • 第二部以“法典”命名的法律!生态环境法典编纂迈出“关键步”
  • 人民日报读者点题:规范涉企执法,怎样防止问题反弹、提振企业信心?
  • 委员呼吁提高政府机构电话号码准确性,辽宁阜新回应