Android 特权许可白名单

和您一起终身学习,这里是程序员Android

本篇文章主要介绍 Android 开发中的部分知识点,通过阅读本篇文章,您将收获以下内容:

一、priv-app 白名单简介
二、添加priv-app 白名单
三、生成priv-app白名单
四、自定义priv-app白名单
五、查找缺少的priv-app权限
六、执行priv-app白名单
七、priv-app 中申请权限未添加特许白名单遇到的坑

一、priv-app 白名单简介

特权应用程序是位于/system/priv-app系统映像目录中的系统应用程序 。从历史上看,设备实施者几乎无法控制哪些特权权限可以授予特权应用程序。从Android 8.0开始,实现者可以在/etc/permissions目录中的系统配置XML文件中明确地将特权应用程序列入白名单。未在这些XML文件中明确列出的应用程序未被授予特权权限。

特别注意事项
仅对 具有package =“android”的应用程序声明的 权限才需要白名单 。Google Play进展使用com.examplecom.android命名空间。

二、添加priv-app 白名单

应用程序的权限白名单可以列在frameworks/base/etc/permissions目录中的单个或多个XML文件中,如下所示:

frameworks/base/etc/permissions/privapp-permissions-OEM_NAME.xml
frameworks/base/etc/permissions/privapp-permissions-DEVICE_NAME.xml

组织内容没有严格的规则。只要所有应用程序/system/priv-app都列入白名单,设备实施者就可以确定内容结构 。例如,GoogleGoogle开发的所有特权应用程序都有一个白名单。我们建议使用以下组织:

  • 已包含在Android开源项目(AOSP)中的应用的权限列于
    /etc/permissions/privapp-permissions-platform.xml
  • Google应用程序的权限列于
    /etc/permissions/privapp-permissions-google.xml
  • 对于其他应用程序,请使用以下形式的文件:
    /etc/permissions/privapp-permissions-DEVICE_NAME.xml

三、生成priv-app白名单

要为系统映像上的所有可用应用程序自动生成白名单,请使用AOSP命令行工具 development/tools/privapp_permissions/privapp_permissions.py。要生成特定于设备的初始版本 privapp-permissions.xml

1.构建系统映像:

  . build/envsetup.sh
    lunch PRODUCT_NAME
    make -j

2.运行该privapp_permissions.py脚本以生成一个privapp-permissions.xml文件,该 文件列出了要列入白名单的所有签名特权权限:

development/tools/privapp_permissions/privapp_permissions.py

此工具生成 XML内容,可以将其用作单个文件或拆分为多个文件/etc/permissions。如果设备已在/etc/permissions目录中包含白名单,则 该工具仅打印差异(即缺少要添加到白名单的特权权限)。这对于审计目的也很有用:添加新版本的应用程序时,该工具会检测所需的其他权限。
3.将生成的文件复制到/etc/permissions目录,系统将在引导期间读取这些文件。

四、自定义priv-app白名单

AOSP包括白名单实现,可根据需要进行自定义。AOSP中包含的应用的权限已列入白名单
/etc/permissions/privapp-permissions-platform.xml。

默认情况下,privapp_permissions.py脚本会生成输出,该输出会自动授予特权应用程序请求的任何权限。如果存在应拒绝的权限,请编辑XML以使用“拒绝权限”标记而不是“权限”标记。例如(frameworks/base/data/etc/privapp-permissions-platform.xml)


    

    
    


    
    
    
    
    
    

    ...

五、查找缺少的priv-app权限

启动新设备时,通过启用过渡日志模式来查找缺少的权限:

ro.control_privapp_permissions=log

可以使用adb 命令获取该属性的值,命令如下:

C:\Users\Administrator>adb root
C:\Users\Administrator>adb remount
Not running as root. Try "adb root" first.
C:\Users\Administrator>adb shell getprop ro.control_privapp_permissions
log
C:\Users\Administrator>
adb 获取特权白名单属性

日志文件中会报告违规,但仍会授予权限。这样可以在提供违规列表的同时使设备保持工作状态。错误消息格式如下:

PackageManager: Privileged permission {PERMISSION_NAME} for package {PACKAGE_NAME} - 
 not in privapp-permissions whitelist

必须通过将应用添加到白名单来解决所有违规问题。如果未添加,即使应用程序位于priv-app路径中,也不会向应用程序授予缺少的权限。

六、执行priv-app白名单

在使用白名单后,通过设置构建属性来启用运行时强制实施ro.control_privapp_permissions=enforce

七、priv-app 中申请权限未添加特许白名单遇到的坑

如果priv-app中申请了一些权限后没有在此文件添加,在强制执行ro.control_privapp_permissions=enforce时候,可能会导致手机无法开机情况。

小编遇到无法开机的异常Log信息如下:

06-04 10:48:38.750  1756  1756 E AndroidRuntime: *** FATAL EXCEPTION IN SYSTEM PROCESS: main
06-04 10:48:38.750  1756  1756 E AndroidRuntime: java.lang.IllegalStateException: Signature|privileged permissions not in privapp-permissions whitelist: {com.android.cellbroadcastreceiver: android.permission.MANAGE_ACTIVITY_STACKS, com.android.cellbroadcastreceiver: android.permission.STATUS_BAR}
06-04 10:48:38.750  1756  1756 E AndroidRuntime:    at com.android.server.pm.permission.PermissionManagerService.systemReady(PermissionManagerService.java:2010)
06-04 10:48:38.750  1756  1756 E AndroidRuntime:    at com.android.server.pm.permission.PermissionManagerService.access$100(PermissionManagerService.java:89)
06-04 10:48:38.750  1756  1756 E AndroidRuntime:    at com.android.server.pm.permission.PermissionManagerService$PermissionManagerInternalImpl.systemReady(PermissionManagerService.java:2057)
06-04 10:48:38.750  1756  1756 E AndroidRuntime:    at com.android.server.pm.PackageManagerService.systemReady(PackageManagerService.java:21446)
06-04 10:48:38.750  1756  1756 E AndroidRuntime:    at com.android.server.SystemServer.startOtherServices(SystemServer.java:1803)
06-04 10:48:38.750  1756  1756 E AndroidRuntime:    at com.android.server.SystemServer.run(SystemServer.java:453)
06-04 10:48:38.750  1756  1756 E AndroidRuntime:    at com.android.server.SystemServer.main(SystemServer.java:316)
06-04 10:48:38.750  1756  1756 E AndroidRuntime:    at java.lang.reflect.Method.invoke(Native Method)
06-04 10:48:38.750  1756  1756 E AndroidRuntime:    at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:504)
06-04 10:48:38.750  1756  1756 E AndroidRuntime:    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:838)

解决方案
根据无法开机的报错信息,需要将小区广播中申请的权限添加到privapp-permissions-platform白名单中。

1.小区广播申请权限AndroidManifest.xml如下:

 1 
   2 
  19 
  22 
  23     
  24     
  25     
  26     
  27     
  28     
  29     
  30     
  31     
  32     
  33     
  34     
  35     
  36     
  37     
  38     
  39     
  40 
  41     
            ... ...
 205 
 206     
 207 

2.需要将 priv-app 在AndroidMainfest.xml 中申请的权限 添加到特许白名单中(frameworks/base/data/etc/privapp-permissions-platform.xml)

   1 
   2 
  17 
  18 
  22 
          ... ... 
  36     
  37         
  38         
  39         
  40         
  41         
  42         
  43         
  44     

         ... ...
452 

至此,本篇已结束。转载网络的文章,小编觉得很优秀,欢迎点击阅读原文,支持原创作者,如有侵权,恳请联系小编删除,欢迎您的建议与指正。同时期待您的关注,感谢您的阅读,谢谢!

你可能感兴趣的:(Android 特权许可白名单)