Android 11 更新破坏了我的文件写入代码

Ada*_*gyi 3 android android-file android-11

我之前使用过这个片段来编写一个带有名称和正文的简单文本文件:

public static File writeTextFile(String sFileName, String sBody) throws IOException {
        File root = new File(Environment.getExternalStorageDirectory(), FOLDER_NAME);

    if (!root.exists()) {
        logFile("Not yet created, creating right now: " + root.getPath());
        root.mkdirs();

        logFile("Creation was successful? " + (root.exists() ? "Yes." : "No."));

    } else {
        logFile("Path exists: " + root.getPath());
    }

  
    File       measurementFile = new File(root, sFileName);
    FileWriter writer  = new FileWriter(measurementFile);
    writer.append(sBody);
    writer.flush();
    writer.close();

    return measurementFile;

}
Run Code Online (Sandbox Code Playgroud)

除了 Android 11 之外,它运行良好,我今天在运行 Android 11 的 OnePlus N10 上进行测试后才意识到这一点。


问题是我没有收到任何描述的错误消息,只是一个简单的异常,并且我似乎无法找到在发生此问题后继续的方法。

 java.io.FileNotFoundException: /storage/emulated/0/example_myapp/content_file_to_upload_1635424827184: open failed: ENOENT (No such file or directory)
     at libcore.io.IoBridge.open(IoBridge.java:492)
     at java.io.FileOutputStream.<init>(FileOutputStream.java:236)
     at java.io.FileOutputStream.<init>(FileOutputStream.java:186)
     at java.io.FileWriter.<init>(FileWriter.java:90)
     at com.myapp.example.util.FileUtil.writeTextFile(FileUtil.java:39)
     at com.myapp.example.services.ConnectionServiceForDownloadData$1.onCharacteristicChanged(ConnectionServiceForDownloadData.java:265)
     at android.bluetooth.BluetoothGatt$1$8.run(BluetoothGatt.java:478)
     at android.bluetooth.BluetoothGatt.runOrQueueCallback(BluetoothGatt.java:780)
     at android.bluetooth.BluetoothGatt.access$200(BluetoothGatt.java:41)
     at android.bluetooth.BluetoothGatt$1.onNotify(BluetoothGatt.java:472)
     at android.bluetooth.IBluetoothGattCallback$Stub.onTransact(IBluetoothGattCallback.java:306)
     at android.os.Binder.execTransactInternal(Binder.java:1170)
     at android.os.Binder.execTransact(Binder.java:1134)
 Caused by: android.system.ErrnoException: open failed: ENOENT (No such file or directory)
     at libcore.io.Linux.open(Native Method)
     at libcore.io.ForwardingOs.open(ForwardingOs.java:166)
     at libcore.io.BlockGuardOs.open(BlockGuardOs.java:254)
     at libcore.io.ForwardingOs.open(ForwardingOs.java:166)
     at android.app.ActivityThread$AndroidOs.open(ActivityThread.java:7924)
     at libcore.io.IoBridge.open(IoBridge.java:478)
    ... 12 more
Run Code Online (Sandbox Code Playgroud)

任何帮助是极大的赞赏。

bla*_*pps 6

文件根 = new File(Environment.getExternalStorageDirectory(), FOLDER_NAME);

改成:

File root = new File(Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_DOCUMENTS), FOLDER_NAME);
Run Code Online (Sandbox Code Playgroud)