我在互联网上阅读了两种检查应用是否获得许可的选项。
选项 1:
getPackageManager().checkPermission(permission_string, packageName);
选项 2:
(PackageInfo.requestedPermissionsFlag[i] & PackageInfo.REQUESTED_PERMISSION_GRANTED) != 0
我在 Android 11 上运行。我正在实施一种机制,在单击应用程序时,将检查权限状态,如果权限不被允许,将提示用户允许它。我只检查“高级”权限,这意味着需要用户从设置屏幕允许它们的权限,例如管理外部存储(适用于 android 11)、drawOverlay、writeSettings 等。无论如何,这是我正在使用的代码:
try {
PackageInfo pi = getPackageManager().getPackageInfo(currAppInfo.getName(), PackageManager.GET_PERMISSIONS);
for(int i=0; i<pi.requestedPermissions.length; i++)
{
String perm = pi.requestedPermissions[i];
PermissionInfo permi = getPackageManager().getPermissionInfo(perm, PackageManager.GET_META_DATA);
if(getPackageManager().checkPermission(perm, currAppInfo.getName()) == 0)
continue;
if(AdvancedPermissionHandler.isAdvancedPermission(permi))
{
AdvancedPermissionHandler.openSettingsPage(permi, currAppInfo.getName(), MainActivity.this);
return;
}
}
} catch (Exception e) {
e.printStackTrace();
}
我面临的唯一问题是,即使我使用了选项 1,即使我使用了选项 2,我的支票也总是出错。意思是,假设我单击一个需要管理外部存储的应用程序,并且当前不允许其状态。我单击应用程序,移动到相应的屏幕,允许权限,返回主屏幕,当我再次单击应用程序时,我没有打开,而是移动到相同的权限屏幕。调试器显示
getPackageManager().checkPermission(permission_string, packageName);
返回 false,即使已授予权限。当我使用选项 2 时也是如此。 所以我的问题是,还有哪些其他方法可以用来确定是否向其他应用授予了权限,或者我在这段代码中做错了什么。
答案 0 :(得分:0)
在进一步挖掘之后,我发现了 AppOps。 这是我用来工作的代码,Android 11:
AppOpsManager appOps = (AppOpsManager)getSystemService(Context.APP_OPS_SERVICE);
ApplicationInfo applicationInfo = getPackageManager().getApplicationInfo(currAppInfo.getName(), 0);
PackageInfo pi = getPackageManager().getPackageInfo(currAppInfo.getName(), PackageManager.GET_PERMISSIONS);
for(int i=0; i<pi.requestedPermissions.length; i++)
{
String perm = pi.requestedPermissions[i];
PermissionInfo permi = getPackageManager().getPermissionInfo(perm, PackageManager.GET_META_DATA);
if(AppOpsManager.permissionToOp(permi.name) == null)
continue;
boolean granted = (appOps.unsafeCheckOpNoThrow(AppOpsManager.permissionToOp(permi.name),applicationInfo.uid,currAppInfo.getName()) == AppOpsManager.MODE_ALLOWED);
if(granted)
continue;
}