打开失败:来自 AsyncTask 中 IoBridge.java 的 EACCES(权限被拒绝)
open failed: EACCES (Permission denied) from IoBridge.java in AsyncTask
我正在尝试通过 FTP 下载文件。基本上我使用 activity 的两个选项卡片段。 RemoteTabFragment 和 LocalTabFragment。
在 LocalTabFragment 中,我在我的下载目录中列出了文件。在 RemoteTabFragment 中,我正在列出远程文件,并且可以选择将远程文件下载到本地下载目录。
对于 FTP 我使用的操作 AsyncTask.Here 是 AsyncTask 的 doInBackground 函数:
protected FTPClient doInBackground(Void... args) {
Log.d("siteobj", site.toString());
try {
FTPClient ftpClient = new FTPClient();
ftpClient.connect(site.get("host"));
ftpClient.setFileType(FTP.BINARY_FILE_TYPE);
ftpClient.enterLocalPassiveMode();
ftpClient.login(site.get("login_name"), site.get("password"));
performTask(ftpClient);
String reply = ftpClient.getReplyString();
if (ftpClient.getReplyString().contains("250")) {
message = "Files loaded";
} else {
message = reply;
}
} catch (Exception e) {
exception = e;
}
return ftpClient;
}
这里是 doInBackground() 中使用的 performTask 方法 method.Here 我只是在 performTask 方法中粘贴下载代码。
private FTPClient performTask (FTPClient ftpClient) {
if(path == null) {
path = "/";
}
try {
switch (task) {
case "download":
ftpClient.changeWorkingDirectory(path);
String filename = args.getString("filename");
String localPath = args.getString("localPath");
File localDir = new File(Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_DOWNLOADS).getAbsoluteFile(), filename);
//File file = new File(localDir, filename);
Log.d("localDir", localDir.getPath());
OutputStream outputStream = new FileOutputStream(localDir);
Log.d("output stream", outputStream.toString());
Boolean success = ftpClient.retrieveFile (filename, outputStream);
workingDirectory = ftpClient.printWorkingDirectory();
Log.d("working directory", workingDirectory);
break;
default:
files = ftpClient.listFiles("/");
}
} catch (IOException ex){
ex.printStackTrace();
//Toast.makeText(context, ex.toString(), Toast.LENGTH_LONG).show();
}
return ftpClient;
}
所以当执行这条语句时:OutputStream outputStream = new FileOutputStream(localDir);
它给出了错误,实际上是异常,下面是异常的确切堆栈跟踪。
12-21 04:13:29.132 412-2013/com.hafiz.ftp W/System.err﹕ java.io.FileNotFoundException: /mnt/sdcard/Download/5021.shtml: open failed: EACCES (Permission denied)
12-21 04:13:29.152 412-2013/com.hafiz.ftp W/System.err﹕ at libcore.io.IoBridge.open(IoBridge.java:406)
12-21 04:13:29.172 412-2013/com.hafiz.ftp W/System.err﹕ at java.io.FileOutputStream.<init>(FileOutputStream.java:88)
12-21 04:13:29.172 412-2013/com.hafiz.ftp W/System.err﹕ at java.io.FileOutputStream.<init>(FileOutputStream.java:73)
12-21 04:13:29.192 412-2013/com.hafiz.ftp W/System.err﹕ at com.hafiz.ftp.FtpTask.performTask(FTPTask.java:119)
12-21 04:13:29.192 412-2013/com.hafiz.ftp W/System.err﹕ at com.hafiz.ftp.FtpTask.doInBackground(FTPTask.java:72)
12-21 04:13:29.202 412-2013/com.hafiz.ftp W/System.err﹕ at com.hafiz.ftp.FtpTask.doInBackground(FTPTask.java:26)
12-21 04:13:29.212 412-2013/com.hafiz.ftp W/System.err﹕ at android.os.AsyncTask.call(AsyncTask.java:264)
12-21 04:13:29.223 412-2013/com.hafiz.ftp W/System.err﹕ at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)
12-21 04:13:29.232 412-2013/com.hafiz.ftp W/System.err﹕ at java.util.concurrent.FutureTask.run(FutureTask.java:137)
12-21 04:13:29.242 412-2013/com.hafiz.ftp W/System.err﹕ at android.os.AsyncTask$SerialExecutor.run(AsyncTask.java:208)
12-21 04:13:29.242 412-2013/com.hafiz.ftp W/System.err﹕ at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076)
12-21 04:13:29.252 412-2013/com.hafiz.ftp W/System.err﹕ at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569)
12-21 04:13:29.262 412-2013/com.hafiz.ftp W/System.err﹕ at java.lang.Thread.run(Thread.java:856)
12-21 04:13:29.272 412-2013/com.hafiz.ftp W/System.err﹕ Caused by: libcore.io.ErrnoException: open failed: EACCES (Permission denied)
12-21 04:13:29.322 412-2013/com.hafiz.ftp W/System.err﹕ at libcore.io.Posix.open(Native Method)
12-21 04:13:29.612 412-418/com.hafiz.ftp D/dalvikvm﹕ GC_CONCURRENT freed 2295K, 21% free 9538K/11975K, paused 12ms+28ms
12-21 04:13:29.712 412-2013/com.hafiz.ftp W/System.err﹕ at libcore.io.BlockGuardOs.open(BlockGuardOs.java:110)
12-21 04:13:30.002 412-2013/com.hafiz.ftp W/System.err﹕ at libcore.io.IoBridge.open(IoBridge.java:390)
12-21 04:13:30.172 412-2013/com.hafiz.ftp W/System.err﹕ ... 12 more
所以你们能说出这是什么原因吗?那是因为我正在使用
OutputStream outputStream = new FileOutputStream(localDir);
在 doInBackground() 方法中?我尝试在 AsyncTask 之外创建 FileOutputStream 并发送 class 的 public 变量。但我仍然面临同样的问题。此外,如果我需要在 AsyncTask 之外使用此方法,请告诉我如何使用它,而我的目的是从 FTP 下载文件并上传到那里。
我在 android 清单文件中的权限和设置是:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.hafiz.ftp" >
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="ANDROID.PERMISSION.READ_EXTERNAL_STORAGE"/>
<uses-permission android:name="ANDROID.PERMISSION.WRITE_EXTERNAL_STORAGE"/>
<uses-permission android:name="android.permission.CHANGE_NETWORK_STATE" />
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:debuggable="true"
android:theme="@style/AppTheme" >
<activity
android:name=".MainActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity
android:name=".TabActivity"
android:label="@string/title_activity_tab" >
</activity>
</application>
</manifest>
请让我知道您认为我做错了什么导致了该异常。如果您知道更好的方法来完成同样的事情,请告诉我。如果您认为缺少某些内容,我需要告诉您以获得更好的答案,请随时提问。
请注意,我发现了很多类似的问题,但其中很多都有不同的答案,所以我想知道问这个问题我做错了什么。所以请不要只是通过点重定向到其他解决方案,还要在这里告诉。
这是一个错误:
<uses-permission android:name="ANDROID.PERMISSION.READ_EXTERNAL_STORAGE"/>
<uses-permission android:name="ANDROID.PERMISSION.WRITE_EXTERNAL_STORAGE"/>
你需要小写 android.permission
.
我正在尝试通过 FTP 下载文件。基本上我使用 activity 的两个选项卡片段。 RemoteTabFragment 和 LocalTabFragment。
在 LocalTabFragment 中,我在我的下载目录中列出了文件。在 RemoteTabFragment 中,我正在列出远程文件,并且可以选择将远程文件下载到本地下载目录。
对于 FTP 我使用的操作 AsyncTask.Here 是 AsyncTask 的 doInBackground 函数:
protected FTPClient doInBackground(Void... args) {
Log.d("siteobj", site.toString());
try {
FTPClient ftpClient = new FTPClient();
ftpClient.connect(site.get("host"));
ftpClient.setFileType(FTP.BINARY_FILE_TYPE);
ftpClient.enterLocalPassiveMode();
ftpClient.login(site.get("login_name"), site.get("password"));
performTask(ftpClient);
String reply = ftpClient.getReplyString();
if (ftpClient.getReplyString().contains("250")) {
message = "Files loaded";
} else {
message = reply;
}
} catch (Exception e) {
exception = e;
}
return ftpClient;
}
这里是 doInBackground() 中使用的 performTask 方法 method.Here 我只是在 performTask 方法中粘贴下载代码。
private FTPClient performTask (FTPClient ftpClient) {
if(path == null) {
path = "/";
}
try {
switch (task) {
case "download":
ftpClient.changeWorkingDirectory(path);
String filename = args.getString("filename");
String localPath = args.getString("localPath");
File localDir = new File(Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_DOWNLOADS).getAbsoluteFile(), filename);
//File file = new File(localDir, filename);
Log.d("localDir", localDir.getPath());
OutputStream outputStream = new FileOutputStream(localDir);
Log.d("output stream", outputStream.toString());
Boolean success = ftpClient.retrieveFile (filename, outputStream);
workingDirectory = ftpClient.printWorkingDirectory();
Log.d("working directory", workingDirectory);
break;
default:
files = ftpClient.listFiles("/");
}
} catch (IOException ex){
ex.printStackTrace();
//Toast.makeText(context, ex.toString(), Toast.LENGTH_LONG).show();
}
return ftpClient;
}
所以当执行这条语句时:OutputStream outputStream = new FileOutputStream(localDir);
它给出了错误,实际上是异常,下面是异常的确切堆栈跟踪。
12-21 04:13:29.132 412-2013/com.hafiz.ftp W/System.err﹕ java.io.FileNotFoundException: /mnt/sdcard/Download/5021.shtml: open failed: EACCES (Permission denied)
12-21 04:13:29.152 412-2013/com.hafiz.ftp W/System.err﹕ at libcore.io.IoBridge.open(IoBridge.java:406)
12-21 04:13:29.172 412-2013/com.hafiz.ftp W/System.err﹕ at java.io.FileOutputStream.<init>(FileOutputStream.java:88)
12-21 04:13:29.172 412-2013/com.hafiz.ftp W/System.err﹕ at java.io.FileOutputStream.<init>(FileOutputStream.java:73)
12-21 04:13:29.192 412-2013/com.hafiz.ftp W/System.err﹕ at com.hafiz.ftp.FtpTask.performTask(FTPTask.java:119)
12-21 04:13:29.192 412-2013/com.hafiz.ftp W/System.err﹕ at com.hafiz.ftp.FtpTask.doInBackground(FTPTask.java:72)
12-21 04:13:29.202 412-2013/com.hafiz.ftp W/System.err﹕ at com.hafiz.ftp.FtpTask.doInBackground(FTPTask.java:26)
12-21 04:13:29.212 412-2013/com.hafiz.ftp W/System.err﹕ at android.os.AsyncTask.call(AsyncTask.java:264)
12-21 04:13:29.223 412-2013/com.hafiz.ftp W/System.err﹕ at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)
12-21 04:13:29.232 412-2013/com.hafiz.ftp W/System.err﹕ at java.util.concurrent.FutureTask.run(FutureTask.java:137)
12-21 04:13:29.242 412-2013/com.hafiz.ftp W/System.err﹕ at android.os.AsyncTask$SerialExecutor.run(AsyncTask.java:208)
12-21 04:13:29.242 412-2013/com.hafiz.ftp W/System.err﹕ at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076)
12-21 04:13:29.252 412-2013/com.hafiz.ftp W/System.err﹕ at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569)
12-21 04:13:29.262 412-2013/com.hafiz.ftp W/System.err﹕ at java.lang.Thread.run(Thread.java:856)
12-21 04:13:29.272 412-2013/com.hafiz.ftp W/System.err﹕ Caused by: libcore.io.ErrnoException: open failed: EACCES (Permission denied)
12-21 04:13:29.322 412-2013/com.hafiz.ftp W/System.err﹕ at libcore.io.Posix.open(Native Method)
12-21 04:13:29.612 412-418/com.hafiz.ftp D/dalvikvm﹕ GC_CONCURRENT freed 2295K, 21% free 9538K/11975K, paused 12ms+28ms
12-21 04:13:29.712 412-2013/com.hafiz.ftp W/System.err﹕ at libcore.io.BlockGuardOs.open(BlockGuardOs.java:110)
12-21 04:13:30.002 412-2013/com.hafiz.ftp W/System.err﹕ at libcore.io.IoBridge.open(IoBridge.java:390)
12-21 04:13:30.172 412-2013/com.hafiz.ftp W/System.err﹕ ... 12 more
所以你们能说出这是什么原因吗?那是因为我正在使用
OutputStream outputStream = new FileOutputStream(localDir);
在 doInBackground() 方法中?我尝试在 AsyncTask 之外创建 FileOutputStream 并发送 class 的 public 变量。但我仍然面临同样的问题。此外,如果我需要在 AsyncTask 之外使用此方法,请告诉我如何使用它,而我的目的是从 FTP 下载文件并上传到那里。
我在 android 清单文件中的权限和设置是:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.hafiz.ftp" >
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="ANDROID.PERMISSION.READ_EXTERNAL_STORAGE"/>
<uses-permission android:name="ANDROID.PERMISSION.WRITE_EXTERNAL_STORAGE"/>
<uses-permission android:name="android.permission.CHANGE_NETWORK_STATE" />
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:debuggable="true"
android:theme="@style/AppTheme" >
<activity
android:name=".MainActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity
android:name=".TabActivity"
android:label="@string/title_activity_tab" >
</activity>
</application>
</manifest>
请让我知道您认为我做错了什么导致了该异常。如果您知道更好的方法来完成同样的事情,请告诉我。如果您认为缺少某些内容,我需要告诉您以获得更好的答案,请随时提问。
请注意,我发现了很多类似的问题,但其中很多都有不同的答案,所以我想知道问这个问题我做错了什么。所以请不要只是通过点重定向到其他解决方案,还要在这里告诉。
这是一个错误:
<uses-permission android:name="ANDROID.PERMISSION.READ_EXTERNAL_STORAGE"/>
<uses-permission android:name="ANDROID.PERMISSION.WRITE_EXTERNAL_STORAGE"/>
你需要小写 android.permission
.