Android 7.0运行时权限弹窗问题的解决

  

Android 7.0系统在运行应用的时候,对权限做了诸多限制,正常的,危险的,签名,signatureOrSystem,取决于保护级别,在确定是否授予权限时,系统可能采取不同的操作。
  

  
      <李>正常表示权限是低风险的,不会对系统,用户或其他应用程序造成危害,李   <李>危险表示权限是高风险的,系统将可能要求用户输入相关信息,才会授予此权限;李   <李>签名表示只有当应用程序所用数字签名与声明引权限的应用程序所用数字签名相同时,才能将权限授给它;李   <李> signatureOrSystem表示将权限授给具有相同数字签名的应用程序或android包类。这一保护级别适和于非常特殊的情况,比如多个供应商需要通过系统映像共享功能时李   
  

运行时权限弹窗问题是很多系统定制的客户要求屏蔽的,一直以来没有特别好的方法,下面我分享一下我自己验证可行的方案

  

<强>方案1,强修改框架核心/java/基地/服务//com/android/server/pm/PackageManagerService和框架核心/java/基地/服务//com/android/server/pm/DefaultPermissionGrantPolicy文件,PackageManagerService文件修改代码如下:

        @Override   公共空间systemReady () {   …   同步(mPackages) {   …   for (int userId: UserManagerService.getInstance () .getUserIds ()) {//如果(! mSettings.areDefaultRuntimePermissionsGrantedLPr (userId)){//注释掉这个判断   grantPermissionsUserIds=ArrayUtils.appendInt (   grantPermissionsUserIds userId);//}   }   }   之前      

DefaultPermissionGrantPolicy文件修改代码如下:

        私人空间grantPermissionsToSysComponentsAndPrivApps (int userId) {   日志。我(标签,“平台组件为用户授予权限”+ userId);      同步(mService.mPackages) {   (PackageParser。包包裹:mService.mPackages.values ()) {//如果(! isSysComponentOrPersistentPlatformSignedPrivAppLPr (pkg)//删掉isSysComponentOrPersistentPlatformSignedPrivAppLPr判断   如果(! doesPackageSupportRuntimePermissions(包裹)   | | pkg.requestedPermissions.isEmpty ()) {   继续;   }   Set权限=new ArraySet<在();   最后一个int permissionCount=pkg.requestedPermissions.size ();   for (int i=0;我& lt;permissionCount;我+ +){   字符串许可=pkg.requestedPermissions.get(我);   BasePermission bp=mService.mSettings.mPermissions.get(许可);   如果(bp !=零,,bp.isRuntime ()) {   permissions.add(许可);   }   }   如果(! permissions.isEmpty ()) {   grantRuntimePermissionsLPw (pkg,权限,真的,userId);   }   }   }   }   之前      

简单说明下这个方案的修改原理,在经前综合症的systemReady方法中会遍历所有拥有默认运行时权限应用,通过遍历它们的标识来赋予权限,注释掉判断是否为拥有运行时权限的应用方法后,会遍历所有应用,遍历应用且赋予权限的操作是在DefaultPermissionGrantPolicy中grantPermissionsToSysComponentsAndPrivApps方法,注释掉判断签名应用和系统应用的方法,普通应用也可以获取所有运行时权限,这样所有应用都不会有运行时权限的弹窗了。

  

<强>方案2,只修改框架核心/java/基地/服务//com/android/server/pm/PackageManagerService文件,修改grantPermissionsLPw方法,代码如下:

        私人空间grantPermissionsLPw (PackageParser。包包裹,布尔取代,   字符串packageOfInterest) {   …/*添加授权第三方应用permssion S */最终字符串thirdPkgName=SystemProperties.get (“persist.thirdparty.packagenames”、" ");      如果(isSystemApp (pkg) | | pkg.packageName.contains (thirdPkgName)) {//xxx为包名   最后一个int permCount=pkg.requestedPermissions.size ();   for (int i=0;我& lt;permCount;我+ +){   最终字符串名称=pkg.requestedPermissions.get(我);   最后BasePermission bp=mSettings.mPermissions.get(名称);   如果(bp !=零,,permissionsState.grantInstallPermission (bp) !=PermissionsState.PERMISSION_OPERATION_FAILURE) {   changeInstallPermission=true;   }   }/*添加授权第三方应用程序许可E */permissionsState.setGlobalGids (mGlobalGids);   …   }      

简单解释下第二中方案的思路,经前综合症在应用安装的时候会根据应用是否为签名应用,系统应用或三方应用来更新权限,这里可以做成白名单的形式,目前通过SystemProperties来获取三方包名可以通过亚洲开发银行或者串口来测试三方应用权限是否可以正常获取。两种方案大家可以自由选择。

Android 7.0运行时权限弹窗问题的解决