Android new File(path).mkdirs() 一直返回false问题,open failed: ENOENT (No such file or directory)

博客指出在compileSdkVersion 29版本中,Manifest配置权限且动态申请权限后,mkdirs一直返回false。经查找,是因为Environment.getExternalStorageDirectory().getPath()方法在该版本被标注为@Deprecated,Android Q手机无法直接访问此路径。最后给出解决方式,先判断sd卡可用性,再根据系统设置目录。

compileSdkVersion: 29版本中

  1. Manifest已经配置权限
  2. 动态申请了权限

出现问题:mkdirs一直返回false

查找问题发现:Environment.getExternalStorageDirectory().getPath(),在compileSdkVersion: 29版本中,该方法标注了@Deprecated,里面已经说明,对于Android Q的手机,应用程序不再可以直接访问此方法返回的路径,所以会一直报错 No such file or directory

解决方式直接上代码
先判断sd卡是否可用,再根据系统设置自己的目录。

    private String environmentFileRoot;//文件根路径
    public String initFileRoot(Context context) {
        if (TextUtils.isEmpty(environmentFileRoot)){
            if (Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)) {//sd卡是否可用
                int currentapiVersion=android.os.Build.VERSION.SDK_INT;//手机系统版本号
                Log.e("FileHelp","SDK_INT::"+currentapiVersion);
                if (currentapiVersion<android.os.Build.VERSION_CODES.Q){
                    environmentFileRoot = Environment.getExternalStorageDirectory().getAbsolutePath();
                }else {
                    File external = context.getExternalFilesDir(null);
                    if (external != null) {
                        environmentFileRoot =  external.getAbsolutePath();
                    }
                }
            }else {
                environmentFileRoot= context.getFilesDir().getAbsolutePath();
            }
        }
        Log.e("FileHelp","environmentFileRoot::"+environmentFileRoot);     
        return environmentFileRoot;
    }
03-21 23:30:13.628 1000 2675 2719 I ActivityManager: Start proc 28941:system/u14s1000 for broadcast {com.android.server.telecom/com.android.server.telecom.components.AppUninstallBroadcastReceiver} 03-21 23:30:13.630 1000 3393 3393 D AolSceneNotifer: updateScreenState Screen INTERNAL on 03-21 23:30:13.631 1410212 28828 28828 W ContextImpl: Failed to ensure /data/user_de/0/com.google.android.permissioncontroller/files: mkdir failed: ENOENT (No such file or directory) 03-21 23:30:13.631 1000 3393 3393 D AolSceneNotifer: updateRotationState Screen INTERNAL USB_TOWARD_DOWN 03-21 23:30:13.632 1410212 28828 28828 W ContextImpl: Failed to ensure /data/user_de/0/com.google.android.permissioncontroller/files: mkdir failed: ENOENT (No such file or directory) 03-21 23:30:13.632 1410212 28828 28828 W FileUtils: Failed to chmod(/data/user_de/0/com.google.android.permissioncontroller/files): android.system.ErrnoException: chmod failed: ENOENT (No such file or directory) 03-21 23:30:13.633 1410212 28828 28828 E LocationAccessCheck: Could not write packages_already_notified_location_access 03-21 23:30:13.633 1410212 28828 28828 E LocationAccessCheck: java.io.FileNotFoundException: /data/user_de/0/com.google.android.permissioncontroller/files/packages_already_notified_location_access: open failed: ENOENT (No such file or directory) 03-21 23:30:13.633 1410212 28828 28828 E LocationAccessCheck: at libcore.io.IoBridge.open(IoBridge.java:574) 03-21 23:30:13.633 1410212 28828 28828 E LocationAccessCheck: at java.io.FileOutputStream.<init>(FileOutputStream.java:259) 03-21 23:30:13.633 1410212 28828 28828 E LocationAccessCheck: at android.app.ContextImpl.openFileOutput(ContextImpl.java:795) 03-21 23:30:13.633 1410212 28828 28828 E LocationAccessCheck: at com.android.permissioncontroller.permission.service.LocationAccessCheck.persistAlreadyNotifiedPackagesLocked(LocationAccessCheck.java:322) 03-21 23:30:13.633 1410212 28828 28828 E LocationAccessCheck: at com.android.permission
03-22
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

feipengwang6666

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值