5

我正在尝试使用新的运行时权限将我的应用程序源代码更新到 Android 6.0。

但是如果用户授予应用程序存储权限,应用程序也无法在'onRequestPermissionsResult'使用'mkdirs'.

在 AndroidManifest.xml 我把'uses-permission'

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.xample.provasd"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk android:minSdkVersion="11" android:targetSdkVersion="23" />

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

    <!-- application, activity, etc -->

然后在 MainActivity 我处理权限请求:

public void executeButton(View view){
        final String[] PERMISSIONS_STORAGE = { Manifest.permission.WRITE_EXTERNAL_STORAGE };
        //Asking request Permissions 
        ActivityCompat.requestPermissions(this,PERMISSIONS_STORAGE, 9);
    }

    @Override
    public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) {
        boolean writeAccepted = false;
        switch(requestCode){
        case 9:
            writeAccepted = grantResults[0]==PackageManager.PERMISSION_GRANTED;
            break;
        }
        if(writeAccepted){
            String state = Environment.getExternalStorageState();
            if (Environment.MEDIA_MOUNTED.equals(state)) {
                File dir = new File(Environment.getExternalStorageDirectory()+"/"+"TestFolder");
                boolean b = dir.mkdirs();
                if(b){
                    Log.i("TAG", "WOW! "+dir+" created!");
                }else{
                    Log.e("TAG", "OPS! "+dir+" NOT created! To be sure: new dir exist? "+dir.exists());
                }
            }
        }       
    }

在模拟器上启动应用程序,显示请求对话框:允许'onRequestPermissionsResult'执行主体的权限(writeAccepted=true)但未创建文件夹!

这是出现在 LogCat 中的内容:

I/TAG(9020): Permission ok
I/TAG(9020): Try to create dir: /storage/3143-1CEA/TestFolder
E/TAG(9020): OPS! /storage/3143-1CEA/TestFolder NOT created! To be sure: new dir exist? false

我不明白原因。

拜托,有人可以帮助我吗?

谢谢,

米尔科

4

1 回答 1

1

问题可能不在于代码。如果您的手机运行的是 Android 6.0,请查看您的 App 是否有足够的权限。

于 2016-03-27T13:50:37.943 回答