我尝试使用ApplicationContext
和我的Service
Context
来访问外部目录。不幸的是,它不断返回null
,而LogCat报告它无法创建外部目录。我确定我有WRITE_STORAGE_PERMISSION
在场,但它仍然不起作用。我的设备正在运行API 10(2.3.3)vanilla android。有什么想法吗?
这是我的清单:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="droid.signboard" android:versionCode="1"
android:versionName="1.0">
<uses-sdk android:minSdkVersion="10" android:targetSdkVersion="10" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<uses-permission android:name="android.permission.CHANGE_WIFI_STATE" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<application android:icon="@drawable/icon" android:label="@string/app_name"
android:name="SignboardApp">
<receiver android:name=".ApplicationStarter">
<intent-filter>
<action android:name="android.intent.action.BOOT_COMPLETED"></action>
<action android:name="droid.signboard.LAUNCHER_START"></action>
</intent-filter>
</receiver>
<activity android:label="@string/app_name"
android:screenOrientation="landscape" android:launchMode="singleTop"
android:name=".view.Signboard">
<intent-filter>
<action android:name="android.intent.action.MAIN"></action>
<category android:name="android.intent.category.LAUNCHER"></category>
</intent-filter>
</activity>
<service android:name=".controller.MasterControllerService">
<intent-filter>
<action
android:name="droid.signboard.LAUNCH_SERVICE_FROM_ACTIVITY"></action>
</intent-filter>
</service>
</application>
</manifest>
这里是代码混乱的地方:
private boolean canWriteEx () {
String state = Environment.getExternalStorageState ();
if (state.equals (Environment.MEDIA_MOUNTED)) {
Log.i (TAG, "Can write to external directory: "
+ context.getExternalFilesDir (null).getAbsolutePath ());
return true;
} else {
Log.i (TAG, "Cannot write to external directory: "
+ context.getExternalFilesDir (null).getAbsolutePath ());
return false;
}
}
代码是Runnable
的方法,由Service
调用。 Runnable
的构造函数以Context
为参数。这是代码使用的Context
。该代码在 成功 的日志调用中引发异常,这意味着外部存储存在且可用。
屡获殊荣的修正:
干净安装不起作用 恢复到API 9不起作用,尽管它早先工作。
答案 0 :(得分:9)
固定,但我真的不知道为什么它现在有效。 我重新启动设备,然后突然间,它会再次运行; Context#getExternalFilesDir ()
已停止返回null
。即使它现在有效(感谢和道具The IT Crowd
的罗伊和莫斯),我应该向Google报告此事吗?
答案 1 :(得分:6)
这是一个老线程,但我遇到了同样的问题,发现我感到惊讶的原因并不常见。当我的设备连接到计算机/ Eclipse时,我试图写入外部存储器..我收到以下错误,
06-25 16:16:09.565:W / ApplicationContext(4290):无法创建外部文件目录 06-25 16:16:09.565:W / System.err(4290):java.io.FileNotFoundException:/full_archive.zip:open failed:EROFS(只读文件系统) 06-25 16:16:09.565:W / System.err(4290):at libcore.io.IoBridge.open(IoBridge.java:416) 06-25 16:16:09.565:W / System.err(4290):at java.io.FileOutputStream。(FileOutputStream.java:88) 06-25 16:16:09.565:W / System.err(4290):at java.io.FileOutputStream。(FileOutputStream.java:73) 06-25 16:16:09.565:W / System.err(4290):at com.seine.trophy.database.DownloaderThread.run(DownloaderThread.java:79) 06-25 16:16:09.573:W / System.err(4290):引起:libcore.io.ErrnoException:open failed:EROFS(只读文件系统) 06-25 16:16:09.573:W / System.err(4290):at libcore.io.Posix.open(Native Method) 06-25 16:16:09.573:W / System.err(4290):at libcore.io.BlockGuardOs.open(BlockGuardOs.java:110) 06-25 16:16:09.573:W / System.err(4290):at libcore.io.IoBridge.open(IoBridge.java:400) 06-25 16:16:09.573:W / System.err(4290):... 3更多
这是来自开发者指南......
注意:如果用户在计算机上安装外部存储设备,则外部存储可能不可用...
简单地从我的电脑/ IDE中取出手机就解决了我的问题。
答案 2 :(得分:2)
您需要在AndroidManifest.xml中拥有WRITE_EXTERNAL_STORAGE权限。至少,这就是为我解决的问题。
在<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
行之前添加行<application ...
。