2
我想在第一次运行我的应用程序时向用户询问所需的所有权限。Android M获取清单中列出的所有危险权限
但是,我不想在代码中对Dangerous Permissions
进行硬编码,因为这会使我的代码变得不那么易于管理。
是否有可能在我可以查询和获取我在Manifest.xml
我想在第一次运行我的应用程序时向用户询问所需的所有权限。Android M获取清单中列出的所有危险权限
但是,我不想在代码中对Dangerous Permissions
进行硬编码,因为这会使我的代码变得不那么易于管理。
是否有可能在我可以查询和获取我在Manifest.xml
已经上市作为CommonsWare在评论中指出所有危险权限的方式,这将是更好地使用所有的一static String[]
危险的权限比使用PackageManager
得到一个列表。您可以使用下面的方法来让你的应用程序的危险权限或任何应用程序的列表:
public static List<PermissionInfo> getDangerousPermissions(Context context, String packageName)
throws PackageManager.NameNotFoundException {
List<PermissionInfo> dangerousPermissions = new ArrayList<>();
PackageManager pm = context.getPackageManager();
PackageInfo packageInfo = pm.getPackageInfo(packageName, PackageManager.GET_PERMISSIONS);
if (packageInfo.requestedPermissions != null) {
for (String requestedPermission : packageInfo.requestedPermissions) {
try {
PermissionInfo permissionInfo = pm.getPermissionInfo(requestedPermission, 0);
switch (permissionInfo.protectionLevel & PermissionInfo.PROTECTION_MASK_BASE) {
case PermissionInfo.PROTECTION_DANGEROUS:
dangerousPermissions.add(permissionInfo);
break;
}
} catch (PackageManager.NameNotFoundException ignored) {
// unknown permission
}
}
}
return dangerousPermissions;
}
用法示例:
try {
List<PermissionInfo> dangerousPermissions = getDangerousPermissions(this, "com.android.chrome");
System.out.println(String.format("%d dangerous permissions:", dangerousPermissions.size()));
for (PermissionInfo dangerousPermission : dangerousPermissions) {
System.out.println(dangerousPermission.name);
}
} catch (PackageManager.NameNotFoundException e) {
e.printStackTrace();
}
输出:
I/System.out: 7 dangerous permissions:
I/System.out: android.permission.ACCESS_COARSE_LOCATION
I/System.out: android.permission.ACCESS_FINE_LOCATION
I/System.out: android.permission.CAMERA
I/System.out: android.permission.GET_ACCOUNTS
I/System.out: android.permission.RECORD_AUDIO
I/System.out: android.permission.WRITE_EXTERNAL_STORAGE
I/System.out: android.permission.READ_EXTERNAL_STORAGE
你肯定欢迎使用'PackageManager'来找出应用程序请求的权限。我想你也可以找出哪些是危险的。保守地说,这将比应该很少改变的权限的静态String []更复杂1-2个数量级。 – CommonsWare