当前位置: 首页 > 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复现
  • 全国台联原会长杨国庆逝世,享年89岁
  • 中老铁路跨境国际旅客突破50万人次
  • 李铁案二审驳回上诉,维持一审有期徒刑20年的判决
  • 举牌超200轮!中铁建7.76亿元竞得北京通州梨园宅地
  • 美国通过《删除法案》:打击未经同意发布他人私密图像,包括“深度伪造”
  • 我国首部《人工智能气象应用服务办法》今天发布