android4.0sd卡读写,Android4.4上读写外置SD卡出错

Android4.4手机上,在外置SD卡创建目录时,报错如下:

11-30 12:49:39.685 32097-32139/com.test.appstore W/System.err: java.io.IOException: open failed: EACCES (Permission denied)

11-30 12:49:39.685 32097-32139/com.test.appstore W/System.err: at java.io.File.createNewFile(File.java:950)

11-30 12:49:39.685 32097-32139/com.test.appstore W/System.err: at com.thin.downloadmanager.DownloadDispatcher.transferData(DownloadDispatcher.java:241)

11-30 12:49:39.685 32097-32139/com.test.appstore W/System.err: at com.thin.downloadmanager.DownloadDispatcher.executeDownload(DownloadDispatcher.java:157)

11-30 12:49:39.685 32097-32139/com.test.appstore W/System.err: at com.thin.downloadmanager.DownloadDispatcher.executeDownload(DownloadDispatcher.java:171)

11-30 12:49:39.695 32097-32139/com.test.appstore W/System.err: at com.thin.downloadmanager.DownloadDispatcher.executeDownload(DownloadDispatcher.java:171)

11-30 12:49:39.695 32097-32139/com.test.appstore W/System.err: at com.thin.downloadmanager.DownloadDispatcher.executeDownload(DownloadDispatcher.java:171)

11-30 12:49:39.695 32097-32139/com.test.appstore W/System.err: at com.thin.downloadmanager.DownloadDispatcher.run(DownloadDispatcher.java:99)

11-30 12:49:39.695 32097-32139/com.test.appstore W/System.err: Caused by: libcore.io.ErrnoException: open failed: EACCES (Permission denied)

11-30 12:49:39.695 32097-32139/com.test.appstore W/System.err: at libcore.io.Posix.open(Native Method)

11-30 12:49:39.695 32097-32139/com.test.appstore W/System.err: at libcore.io.BlockGuardOs.open(BlockGuardOs.java:110)

11-30 12:49:39.695 32097-32139/com.test.appstore W/System.err: at java.io.File.createNewFile(File.java:943)

11-30 12:49:39.695 32097-32139/com.test.appstore W/System.err: ... 6 more

说明一下我这边的代码。

AndroidManifest中已经声明了读写SD卡的权限:

同时,在使用外置SD卡时,已经判断了外置sd卡的加载状态:

private static boolean isSdAvailable() {

return Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED);

}

private static String getDir(Context context, String cache) {

StringBuilder path = new StringBuilder();

if (isSdAvailable()) {

// 如果内存卡可以,则存储在内存卡上

path.append(Environment.getExternalStorageDirectory().getAbsolutePath());

path.append(File.separator);

path.append(ROOT);

path.append(File.separator);

path.append(cache);

path.append(File.separator);

} else {

// 存放在手机内存中

File fileDir = context.getCacheDir();

path.append(fileDir.getAbsolutePath());

path.append(File.separator);

path.append(cache);

path.append(File.separator);

}

return path.toString();

}

求指导一下原因。

补充:我这边找到了出问题的手机,从手机状态来看,是手机的SD卡权限设置错误导致的。代码本身已经是没有问题,故关闭该问题。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值