我有以下问题:
我的应用程序通过MDM系统分发,并在Android for Work中运行。在某些情况下,应用程序必须暂时终止DnD模式。要实现此目的,用户必须在应用程序启动时授予DnD权限。
到现在为止还挺好。如果我在非托管区域安装应用程序,则应用程序会显示在列表中,并且可以毫无问题地授予权限。只要应用程序通过MDM系统分发,应用程序就不再出现在列表中,并且无法授予权限。所有授权都已在MDM系统中授予。例如,我通过MDM系统分发了Google App。此应用程序显示在列表中。
在Manifest中我设置了以下权限:
<uses-permission android:name="android.permission.ACCESS_NOTIFICATION_POLICY" />
启动应用程序时,将执行以下代码:
NotificationManager nm = (NotificationManager).getApplicationContext().getSystemService(Context.NOTIFICATION_SERVICE);
if(android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.M && !nm.isNotificationPolicyAccessGranted()) {
Intent intent = new
Intent(Settings.ACTION_NOTIFICATION_POLICY_ACCESS_SETTINGS);
startActivity(intent);
}
只有DnD权限才会出现此问题。所有其他权限(如叠加权限)都会显示没有问题。
我希望有人能帮助我。
根据Android文档:不可能
用户可以从此处授予和拒绝访问“请勿打扰”配置。托管配置文件无法授予“请勿打扰”访问权限。
我还没有找到解决问题的正确方法,但我找到了一种解决方法,可以在工作区中显示应用程序。如果私有区域中也安装了相同的应用程序,则该应用程序似乎仅显示在对话框中。如果应用程序未安装在私有区域中,则它也不会出现在工作区中。我的解决方法是在私人和工作区域安装应用程序。在授予工作区域权限后,我从私有区域中删除了该应用程序。就像我说的那样,它不是问题本身的解决方案,但它起作用了。对我而言,这看起来像是Android中的一个错误,因为对于所有其他权限,应用程序会出现在列表中
我们在应用SignOnSite时遇到了同样的问题。除非我们也在个人空间中安装应用程序,否则无法访问DnD功能以进行紧急疏散。这样做有风险,所以最终只是在个人空间中安装应用程序。将Intune用于我们的MDM。
试试这个 -
Intent intent = new Intent("android.settings.NOTIFICATION_POLICY_ACCESS_SETTINGS");
startActivity(intent);