托管配置文件中的Android请勿打扰(DnD)权限

问题描述 投票:3回答:2

我有以下问题:

我的应用程序通过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-permissions mdm android-for-work android-enterprise
2个回答
1
投票

根据Android文档:不可能

用户可以从此处授予和拒绝访问“请勿打扰”配置。托管配置文件无法授予“请勿打扰”访问权限。


0
投票

我还没有找到解决问题的正确方法,但我找到了一种解决方法,可以在工作区中显示应用程序。如果私有区域中也安装了相同的应用程序,则该应用程序似乎仅显示在对话框中。如果应用程序未安装在私有区域中,则它也不会出现在工作区中。我的解决方法是在私人和工作区域安装应用程序。在授予工作区域权限后,我从私有区域中删除了该应用程序。就像我说的那样,它不是问题本身的解决方案,但它起作用了。对我而言,这看起来像是Android中的一个错误,因为对于所有其他权限,应用程序会出现在列表中


0
投票

我们在应用SignOnSite时遇到了同样的问题。除非我们也在个人空间中安装应用程序,否则无法访问DnD功能以进行紧急疏散。这样做有风险,所以最终只是在个人空间中安装应用程序。将Intune用于我们的MDM。


-1
投票

试试这个 -

Intent intent = new Intent("android.settings.NOTIFICATION_POLICY_ACCESS_SETTINGS");
    startActivity(intent);
© www.soinside.com 2019 - 2024. All rights reserved.