无法使用mkdirs在Android 6.0上创建目录(存储权限ok)

时间:2016-02-13 00:32:14

标签: android storage mkdirs

我尝试使用新的运行时权限将我的应用源代码更新为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

我不明白原因。

请有人可以帮助我吗?

谢谢,

的Mirko

1 个答案:

答案 0 :(得分:1)

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