https://source.android.google.cn/devices/tech/config/perms-whitelist?hl=zh-cn
特许权限白名单
特权应用是位于系统映像 /system/priv-app
目录下的系统应用。过去,设备实现人员几乎无法控制可以向特权应用授予哪些签名|特许权限。从 Android 8.0 开始,实现人员可以将特权应用显式加入到 /etc/permissions
目录下的系统配置 XML 文件的白名单中。未在这些 XML 文件中明确列出的应用不会被授予特许权限。
添加白名单
应用的权限白名单可列在位于 frameworks/base/etc/permissions
目录下的单个或多个 XML 文件中,如下所示:
/etc/permissions/privapp-permissions-OEM_NAME.xml
/etc/permissions/privapp-permissions-DEVICE_NAME.xml
对于如何组织内容,没有严格的规则。设备实现人员可以决定内容结构,只要将 /system/priv-app
下的所有应用均列入白名单即可。例如,Google 针对由 Google 开发的所有特权应用提供了一个白名单。我们建议使用以下组织方式:
- 对于已包含在 Android 开源项目 (AOSP) 树中的应用,将其权限列在
/etc/permissions/privapp-permissions-platform.xml
中。 - 对于 Google 应用,请将其权限列在
/etc/permissions/privapp-permissions-google.xml
中。 - 对于其他应用,请使用以下格式的文件:
/etc/permissions/privapp-permissions-DEVICE_NAME.xml
。
生成白名单
要针对系统映像上提供的所有应用自动生成白名单,请使用位于以下位置的 AOSP 命令行工具:development/tools/privapp_permissions/privapp_permissions.py
。要生成特定于设备的 privapp-permissions.xml
的初始版本,请执行以下操作:
- 编译系统
. build/envsetup.sh
lunch PRODUCT_NAME
make -j
2.运行 privapp_permissions.py
脚本以生成一个 privapp-permissions.xml
文件,该文件会列出需要列入白名单的所有签名|特许权限:
development/tools/privapp_permissions/privapp_permissions.py
此工具会打印可在 /etc/permissions
下作为单个文件或拆分为多个文件的 XML 内容。 如果设备已在/etc/permissions
目录下包含白名单,则该工具将仅打印出差异内容(也就是说,只打印缺少的将列入白名单的签名|特许权限)。这对审核也很有用,当添加新版本的应用时,该工具会检测所需的其他权限。
3. 将生成的文件复制到 /etc/permissions
目录下,系统在启动过程中将从这里读取这些文件。
自定义白名单
AOSP 包含可视需要自定义的白名单实现。 对于包含在 AOSP 中的应用,其权限已在 /etc/permissions/privapp-permissions-platform.xml
中列入白名单。
默认情况下,privapp_permissions.py
脚本生成的输出会自动授予特权应用所请求的任何权限。如果有应被拒绝的权限,请修改 XML 以使用“拒绝权限”标记而非“权限”标记。例如:
<!-- This XML file declares which signature|privileged permissions should be granted to privileged applications that come with the platform --> <permissions> <privapp-permissions package="com.android.backupconfirm"> <permission name="android.permission.BACKUP"/> <permission name="android.permission.CRYPT_KEEPER"/> </privapp-permissions> <privapp-permissions package="com.android.cellbroadcastreceiver"> <!-- don't allow application to interact across users --> <deny-permission name="android.permission.INTERACT_ACROSS_USERS"/> <permission name="android.permission.MANAGE_USERS"/> <permission name="android.permission.MODIFY_PHONE_STATE"/> <permission name="android.permission.READ_PRIVILEGED_PHONE_STATE"/> <permission name="android.permission.RECEIVE_EMERGENCY_BROADCAST"/> </privapp-permissions> ...
查找缺少的权限
在启动新设备时,可通过启用过渡日志模式来查找缺少的权限:
ro.control_privapp_permissions=log
违规行为会在日志文件中予以报告,但仍然会授予权限。 这样可在提供违规行为列表的同时,使设备仍然处于工作状态。错误消息格式如下:
PackageManager: Privileged permission {PERMISSION_NAME} for package {PACKAGE_NAME} - not in privapp-permissions whitelist
所有违规行为均必须通过将应用加入白名单来予以解决。如果未加入,这些应用将不会被授予缺少的权限,即使它们位于 priv-app 路径中也是如此。
强制执行白名单
白名单列好后,可通过设置版本属性 ro.control_privapp_permissions=enforce
来启用运行时强制执行。
注意:ro.control_privapp_permissions
属性状态必须符合 CDD 部分 9.1 的要求。
最后
以上就是潇洒铃铛最近收集整理的关于Android O 开始,特许权限白名单https://source.android.google.cn/devices/tech/config/perms-whitelist?hl=zh-cn特许权限白名单的全部内容,更多相关Android内容请搜索靠谱客的其他文章。
发表评论 取消回复