java.io.FileNotFoundException :(允许拒绝)使用ObjectOutputStream编写对象时

cjn*_*ash 1 java android android-permissions

我一直试图解决这个问题几个小时,我非常沮丧,所以我来找你们一些指导.

我试图保存并检索我创建的用户对象.我想这样做,以便我可以从我的应用程序中的任何意图保存和检索此User对象,所以我决定使用FileInput和Output流.我在下面列出了我的代码.

这是我的输出数据方法:

public static void serializeDataOut(User ish) {
    try {
        String path = Environment.getExternalStorageDirectory().getAbsolutePath();
        File newFile = new File(path + "myFile.ser");
        FileOutputStream fos = new FileOutputStream(newFile);
        ObjectOutputStream oos = new ObjectOutputStream(fos);
        oos.writeObject(ish);
        oos.flush();
        oos.close();
    } catch (IOException e) {
        e.printStackTrace();
    }
}
Run Code Online (Sandbox Code Playgroud)

这是我的输入数据方法:

public static User serializeDataIn(){
    try{
        String path = Environment.getExternalStorageDirectory().getAbsolutePath();
        FileInputStream fin = new FileInputStream(path + "myFile.ser");
        ObjectInputStream ois = new ObjectInputStream(fin);
        User iUser = (User) ois.readObject();
        ois.close();
        return iUser;
    } catch (IOException | ClassNotFoundException e) {
        e.printStackTrace();
        return null;
    }
}
Run Code Online (Sandbox Code Playgroud)

注意:这两个方法都驻留在我的User类中,它也实现了Serializable.

文件路径的整个错误如下所示:java.io.FileNotFoundException: /storage/emulated/0myFile.ser (Permission denied)它出现在这一行:FileOutputStream fos = new FileOutputStream(newFile);当我从不同的意图调用它时,如下所示:User.serializeDataOut(addingUser);其中addingUser是一个有效的User对象.

在异常日志中看到(权限被拒绝)之后我做的第一件事是进入我的清单并检查我是否允许我的应用程序读取和写入存储,我实际上做了.我在下面包含了我的权限:

<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
Run Code Online (Sandbox Code Playgroud)

然后我读到有些人有错误的路径,更具体地说不包括绝对路径,然后我编辑我的代码包括Environment.getExternalStorageDirectory().getAbsolutePath();部分,我很确定我使用正确.

我也确定,因为我在模拟器上测试它,我已经启用了SD卡,模拟器有一个SD文件夹.我检查了它确实有一个SD卡文件夹,我也在S8上测试了这个应用程序,我得到了同样的错误.

我到底错在了什么?我想要做的就是保存一个User对象并将其检索到其他地方,并且我完全可以使用先前的文件被覆盖并且一次只保存一个用户.

还有一些可能与我刚刚注意到的相关:在我的Android监视器中大约每3-5秒,即使在我杀死我的应用程序之后,仍会出现错误.错误看起来像这样:onFatalError, processing error from engine(4) com.google.android.apps.gsa.shared.speech.a.g: Error reading from input stream虽然我只能假设这不是问题的根源,但我只想添加它,以防它可以提供帮助.谢谢

Kau*_*l28 8

您已在清单中添加了权限,因此我确定您不会询问运行时权限.如果您使用的是SDK 23或更高版本,请询问运行时权限.作为参考我在这里添加一些片段:

if(Build.VERSION.SDK_INT>22){
     requestPermissions(new String[] {YOUR_PERMISSIONS AS STRING}, 1);
}
Run Code Online (Sandbox Code Playgroud)

并检查是否授予权限,您需要使用onRequestPermissionResults()方法.

@Override
public void onRequestPermissionsResult(int requestCode,
                                       String permissions[], int[] grantResults) {
    switch (requestCode) {
        case 1: {
            if (!(grantResults.length > 0
                    && grantResults[0] == PackageManager.PERMISSION_GRANTED && grantResults[1] == PackageManager.PERMISSION_GRANTED)) {
                Toast.makeText(addAlarm.this, "Permission denied to access your location.", Toast.LENGTH_SHORT).show();
            }
        }
    }
}
Run Code Online (Sandbox Code Playgroud)


P.J*_*sch 5

java.io.FileNotFoundException: /storage/emulated/0myFile.ser看起来像你在路径中缺少'/'.

使用

String path = Environment.getExternalStorageDirectory().getAbsolutePath() + '/';
Run Code Online (Sandbox Code Playgroud)