请求权限 NameNotFoundException Android M

3

I have the following code:

public static void requestPermissions(final Activity activity){

    System.out.println("Permission 0 : " + activity.getPackageName());

    int permission = activity.getPackageManager().checkPermission(Manifest.permission.WRITE_EXTERNAL_STORAGE, activity.getPackageName());

    if(permission != PackageManager.PERMISSION_GRANTED){
        PackageManager pm = activity.getPackageManager();

        try {
            PackageInfo pi = pm.getPackageInfo(activity.getPackageName(), PackageManager.GET_ACTIVITIES);

            System.out.println("Permission package info : " + pi);
        } catch (NameNotFoundException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

        System.out.println("Permission 1 : " + activity);
        ActivityCompat.requestPermissions(activity, new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE}, 0xFFEEDDCC);
    }
}

无论我如何尝试,我总是得到以下结果:
10-19 17:35:31.642: I/System.out(27952): Permission 0 : com.example.testappandroid
10-19 17:35:31.643: I/System.out(27952): Permission package info : PackageInfo{7b81ba7 com.example.testappandroid}
10-19 17:35:31.643: I/System.out(27952): Permission 1 : com.example.testappandroid.MainActivity@c40298e
10-19 17:35:31.644: I/ActivityManager(862): START u0 {act=android.content.pm.action.REQUEST_PERMISSIONS pkg=com.google.android.packageinstaller cmp=com.google.android.packageinstaller/com.android.packageinstaller.permission.ui.GrantPermissionsActivity (has extras)} from uid 10109 on display 0
10-19 17:35:31.668: I/GrantPermissionsActivity(4527): No package: null
10-19 17:35:31.668: I/GrantPermissionsActivity(4527): android.content.pm.PackageManager$NameNotFoundException
10-19 17:35:31.668: I/GrantPermissionsActivity(4527):   at android.app.ApplicationPackageManager.getPackageInfo(ApplicationPackageManager.java:137)
10-19 17:35:31.668: I/GrantPermissionsActivity(4527):   at com.android.packageinstaller.permission.ui.GrantPermissionsActivity.getCallingPackageInfo(GrantPermissionsActivity.java:312)
10-19 17:35:31.668: I/GrantPermissionsActivity(4527):   at com.android.packageinstaller.permission.ui.GrantPermissionsActivity.onCreate(GrantPermissionsActivity.java:94)

这可能是一个非常简单的问题。传递给requestPermissions函数的活动是主活动,如您从LogCat日志中可以看到的那样。PackageManager.getPackageInfo()的使用似乎也是正确的,因为如果我将其隔离,它会按预期工作。

此外,Manifest.permission.WRITE_EXTERNAL_STORAGE在清单文件中已定义,正如预期的那样。

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>

编辑

一个重要的事实是,我的静态函数requestPermissions(Activity)定义在一个外部库中,例如叫做utils.jar。因此,如果我在MainActivity.java中编写以下内容:

protected void onStart(){
    super.onStart();
    final Activity act = this;
    Utils.requestPermissions(act); // in utils.jar
}

它会失败。如果我写成这样:

protected void onStart(){
    super.onStart();
    final Activity act = this;
    ActivityCompat.requestPermissions(act, new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE}, 1);
}

如预期一样,它会请求权限。

编辑结束

有人之前遇到过这种情况并能提供一些信息吗?非常感谢。


我敢打赌你的Utils.jar不是一个Android库,也就是说它不是在Android Studio中的库模块。 - greywolf82
我在Android 6.0 Nexus 6 (MRA58N)上测试了您的代码。我将请求代码“0xFFEEDDCC”替换为“1”(我认为这是一个笔误)。我还直接在我的活动中定义了您的“requestPermissions()”。它起作用了。 - cuihtlauac
2个回答

3

只需将requestCode的值更改为正数即可。

ActivityCompat.requestPermissions 在深处调用了 startActivityForResult,并使用了您的 requestCode。如果它是负数,则会抛出与您相同的异常:

I/GrantPermissionsActivity: No package: null
                            android.content.pm.PackageManager$NameNotFoundException

只需更改requestCode,它就可以像应用程序一样在库中工作。例如:

ActivityCompat.requestPermissions(activity, new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE}, 101);

这个项目已经关闭了一段时间,我想我已经为此找到了一个解决方法。我无法再检查你的答案,但我仍然会将其标记为正确的。谢谢! - nokto

0

我认为接受的答案可能不正确,因为我已经使用了正面请求密钥,但仍然遇到了这个异常。我遇到此异常的原因是因为我传递给requestPermission方法的活动引用为空,也就是说,在我请求权限之前,活动实际上已经结束,因此我才会收到这个异常。

所以请确保您传递给requestPermission的活动/片段实例不为空。

希望能对你有所帮助。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接