当前位置: 首页 > 知识库问答 >
问题:

Android M权限:对shouldShowRequestPermissionRationale()函数的用法感到困惑

曾丰茂
2023-03-14

我正在查看关于Android M中新权限模型的官方文档,其中谈到了ShouldShowRequestPermissionRationale()函数,如果应用程序先前请求了此权限,而用户拒绝了该请求,则该函数返回true。如果用户过去拒绝了权限请求并选择了“不再询问”选项,则此方法返回false

但我们如何区分以下两种情况呢?

情况1:应用程序没有权限,而且用户之前没有被请求获得该权限。在本例中,shouldShowRequestPermissionRationale()将返回false,因为这是我们第一次询问用户。

情况2:用户拒绝了权限并选择了“Don't ask Again”,在这种情况下,shouldShowRequestPermissionRationale()也将返回false。

我想发送用户到应用程序的设置页面在情况2。我该如何区分这两种情况呢?

共有1个答案

荣俊杰
2023-03-14

在M Preview 1之后,如果第一次显示对话框,则没有Never ask again复选框。

如果用户拒绝权限请求,则在第二次请求权限时,权限对话框中将有一个“永不再次请求”复选框。

所以逻辑应该是这样的:

>

  • 请求权限:

    if (ContextCompat.checkSelfPermission(context, Manifest.permission.WRITE_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED) {
        ActivityCompat.requestPermissions(context, new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE}, REQUEST_CODE);
    } else {
        //Do the stuff that requires permission...
    }
    

    检查OnRequestPermissionsResult中是否拒绝或授予了权限。

    如果先前拒绝了该权限,这次将在权限对话框中出现“永不再次询问”复选框。

    调用ShouldShowRequestPermissionRationale查看用户是否选中了Never ask Again。ShouldShowRequestPermissionRationale方法仅在用户选择了Never ask again或设备策略禁止应用程序具有该权限时才返回false:

    if (grantResults.length > 0){
        if(grantResults[0] == PackageManager.PERMISSION_GRANTED) {
            //Do the stuff that requires permission...
        }else if (grantResults[0] == PackageManager.PERMISSION_DENIED){
            // Should we show an explanation?
            if (ActivityCompat.shouldShowRequestPermissionRationale(context, Manifest.permission.WRITE_EXTERNAL_STORAGE)) {
                //Show permission explanation dialog...
            }else{
                //Never ask again selected, or device policy prohibits the app from having that permission.
                //So, disable that feature, or fall back to another situation...
            }
        }
    }
    

    因此,您不必跟踪用户是否勾选了Never ask again或Not。

  •  类似资料:
    • 问题内容: 与此代码有点混淆。 我在pg-go 仓库中找到了这段代码,不知道为什么这样声明。请解释一下用这种方式声明变量的用例是什么。 问题答案: 这在运行时不会执行任何操作,但是除非类型满足接口要求,否则编译将失败。这是一种静态断言。

    • 我正在尝试提出一种解决方案,它涉及在连接操作之后应用一些逻辑,从多个中的中选择一个事件。这类似于reduce函数,但它只返回1个元素,而不是递增地返回。因此最终结果将是单个(,对,而不是一个 每个键保证只到达一次。 假设像上面这样的连接操作,它用4个生成了1个,成功地连接并收集在。现在,我想做的是,立即访问这些值,并执行一些逻辑以将正确匹配到一个。例如,对于上面的数据集,我需要(,和)。 将为每个

    • 所以我一直在读Kafka的语义学,我对它的工作原理有点困惑。 我理解生产者如何避免发送重复的消息(以防代理的ack失败),但我不明白的是,在消费者处理消息但在提交偏移量之前崩溃的情况下,一次是如何工作的。Kafka不会在这种情况下重试吗?

    • 但是如果我对if语句进行注释,则输出是正确的,即 所以,我不知道它为什么会发生,如何修复?这是我的代码:

    • 问题内容: 我可以理解以下定义: 每个对象都有一个标识,一个类型和一个值。一旦创建了对象,其身份就永远不会改变。您可能会认为它是对象在内存中的地址。所述操作者比较两个对象的身份; 该函数返回一个表示其身份的整数。 我认为上面的定义在创建“某物”时起作用,例如: 但是我不理解: 我还没有创建任何东西。那么整数“ 1”如何具有ID?这是否意味着只要我在Python Shell中“提及” 1,便立即将其

    • 问题内容: 我已经在eclipse中创建了一个项目,并添加了Maven依赖项。在Eclipse中,它表示我正在使用JRE 1.5。一切在Eclipse中都可以正常运行,例如,我可以运行测试。 当我尝试从终端运行时,出现以下错误。 …在-source 1.3中不支持泛型(使用-source 5或更高版本来启用泛型)… 看来,Maven认为我正在使用JRE 1.3,并且无法识别泛型或for-each循