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

【大前端】【Android】获取第三方APK安装信息

一、能获取哪些 APK 信息?

✅ Android 允许获取(常见)

信息是否可获取说明
包名(packageName)核心标识
版本号 / versionCodeversionName / longVersionCode
应用名label
安装时间 / 更新时间firstInstallTime
APK 路径⚠️Android 10+ 受限
签名信息⚠️Android 9+ 需新 API
UID系统分配
是否系统应用flag

❌ 基本禁止 / 强限制

行为说明
获取「所有已安装应用列表」Android 11+ 默认禁止
扫描竞品 / 上报Play 风控高危
读取 APK 文件内容Scoped Storage 限制

二、Android 版本关键分水岭(非常重要)

版本变化
Android 8-几乎无限制
Android 9签名 API 变化
Android 10APK 路径受限
Android 11+包可见性(Package Visibility)机制

三、Android 11+ 必须理解的「包可见性」

👉你“看得见”的 App,才能获取 APK 信息

1️⃣ Manifest 声明可见包(强烈推荐)

<manifest ...> <queries> <!-- 指定包名 --> <package android:name="com.tencent.mm" /> <!-- 指定 Intent --> <intent> <action android:name="android.intent.action.MAIN"/> <category android:name="android.intent.category.LAUNCHER"/> </intent> </queries> </manifest>

📌 特点:

  • 白名单机制

  • 审核重点检查

  • 数量不宜多


2️⃣ 查询所有应用(高危)

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

🚨Google Play 强监管权限

  • 非文件管理 / 设备管理 / 安全类应用100%拒审

  • 必须在 Play Console 写强理由


四、核心代码示例(通用)

1️⃣ 获取单个应用 APK 信息(推荐)

PackageManager pm = context.getPackageManager(); try { PackageInfo info = pm.getPackageInfo( "com.tencent.mm", PackageManager.GET_SIGNING_CERTIFICATES ); String packageName = info.packageName; String versionName = info.versionName; long versionCode = info.getLongVersionCode(); long installTime = info.firstInstallTime; long updateTime = info.lastUpdateTime; String apkPath = info.applicationInfo.sourceDir; } catch (PackageManager.NameNotFoundException e) { // 未安装 }

2️⃣ 获取应用名 / 图标

ApplicationInfo ai = pm.getApplicationInfo("com.tencent.mm", 0); String appName = pm.getApplicationLabel(ai).toString(); Drawable icon = pm.getApplicationIcon(ai);

3️⃣ 获取签名信息(Android 9+ 正确姿势)

PackageInfo info = pm.getPackageInfo( "com.tencent.mm", PackageManager.GET_SIGNING_CERTIFICATES ); SigningInfo signingInfo = info.signingInfo; Signature[] signatures = signingInfo.hasMultipleSigners() ? signingInfo.getApkContentsSigners() : signingInfo.getSigningCertificateHistory();

五、列出“可见”的所有应用(谨慎)

List<PackageInfo> list = pm.getInstalledPackages(PackageManager.GET_META_DATA);

⚠️ Android 11+ 只能拿到:

  • 自己

  • <queries>声明的

  • 系统允许的


六、APK 文件信息(不需要已安装)

解析本地 APK(安装包)

PackageInfo info = pm.getPackageArchiveInfo( "/sdcard/test.apk", PackageManager.GET_ACTIVITIES ); if (info != null) { ApplicationInfo appInfo = info.applicationInfo; appInfo.sourceDir = appInfo.publicSourceDir = "/sdcard/test.apk"; String pkg = info.packageName; }

📌 适合:

  • 文件管理器

  • APK 安装前检测


七、风控 & 审核建议(非常重要)

❌ 高风险行为

  • 静默扫描已安装 App

  • 上报完整 App 列表

  • 未声明用途调用 QUERY_ALL_PACKAGES

✅ 合规建议

  • 只查业务必要 App

  • 白名单 + queries

  • 明示用途(跳转 / 兼容性)


八、常见业务场景 → 推荐方案

需求推荐
判断是否安装微信指定包名查询
App 跳转PackageManager + Intent
设备风控行为 + 网络
APK 检测本地解析 APK
竞品分析❌ 不合规

九、一句话总结

Android 可以获取第三方 APK 信息,但:

  • Android 11+你看不见 = 拿不到

  • QUERY_ALL_PACKAGES= 审核高压线

  • 白名单 + 单包查询才是正道

http://www.cnnetsun.cn/news/135634.html

相关文章:

  • 【大前端】【iOS】iOS 真实项目可落地目录结构方案
  • “在我电脑上明明是好的”:我用这套云原生工作流,终结了团队内耗
  • 揭秘MCP服务发现:构建智能AI工具生态系统的核心技术
  • 智能笔记管理:如何高效组织你的每日任务与灵感
  • 终极指南:如何快速掌握 My Mind 免费在线思维导图工具
  • Vim插件管理器VAM终极指南:从零开始构建高效开发环境
  • AgentWeb终极指南:Android混合开发的一站式解决方案
  • 事件循环机制
  • TikTok 电商全球新棋局:从野蛮生长到精耕细作,谁能站稳脚跟?
  • 创建Mysql 用户 并赋权
  • 完整指南:如何快速掌握Vue可视化打印解决方案
  • Three-DXF深度解析:在浏览器中实现专业级CAD文件渲染
  • P2MS:比特币的多重签名机制与比特鹰的技术解析
  • 终极AI字幕生成指南:快速掌握智能字幕处理技巧
  • C语言程序设计教学指导:突破误区,设计有效实验项目
  • DirectX 9.0b SDK介绍:核心组件、在游戏中的重要性
  • AgentWeb混合开发终极指南:5步实现原生与Web无缝融合
  • 新手如何挖漏洞?看这一篇足够
  • 001 PyTorch实战:手写数字识别(MNIST)从零开始
  • 基于LCL滤波器的单相逆变器并网控制电路仿真研究:dq坐标系网侧电流闭环控制的实现与验证
  • RAG开发避坑指南:12个常见痛点与解决方案,从入门到精通,收藏这篇就够了!
  • 5分钟搞定Python控制Android设备:py-scrcpy-client实战指南
  • Simple Live:跨平台直播聚合神器,重新定义你的观看方式
  • 谷歌 Gemini 3 内测引爆业内讨论:为AI行业带来了哪些惊人的突破?
  • T型槽铸铁平台:工业基石与现代制造的完美融合
  • 基于Spring Boot的校园部门资料管理系统
  • Android截屏限制解决方案:DisableFlagSecure使用指南
  • 完全掌握Mac菜单栏图标隐藏技巧:Dozer深度实战指南
  • 教你快速从Vue 开发者 → React开发者转变!
  • AI薪资暴涨到4.7万/月!人才争夺白热化,程序员必学大模型技能,建议收藏