【问题标题】:Write a log to a txt file android将日志写入txt文件android
【发布时间】:2020-06-27 22:43:06
【问题描述】:

我有一个应用程序和一些事件,我想将它们保存在下载中的 txt 文件中。 我有以下代码,但出现异常(权限被拒绝)。我有 Android 10 Samsung S9 并且我已授予所有权限(写入外部存储)

 val externalStorageDir = Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_DOWNLOADS);
            val myFile = File(externalStorageDir, "mylog.txt");

            if (myFile.exists()) {
                try {
                    val fostream = FileOutputStream(myFile);
                    val oswriter = OutputStreamWriter(fostream);
                    val bwriter = BufferedWriter(oswriter);
                    bwriter.write("Hi James. This is a message");
                    bwriter.newLine();
                    bwriter.close();
                    oswriter.close();
                    fostream.close();
                } catch (e: IOException) {
                    e.printStackTrace();
                }
            } else {
                try {
                    myFile.createNewFile();
                } catch (e: IOException) {
                    e.printStackTrace();
                }
            }

我得到的例外是这个

java.io.IOException: Permission denied
W:     at java.io.UnixFileSystem.createFileExclusively0(Native Method)
W:     at java.io.UnixFileSystem.createFileExclusively(UnixFileSystem.java:317)
W:     at java.io.File.createNewFile(File.java:1008)
W:     at package_name.utilities.SystemUtils$Companion.writefile(SystemUtils.kt:188)
W:     at package_name.ui.activities.SplashActivity.onCreate(SplashActivity.kt:37)
W:     at android.app.Activity.performCreate(Activity.java:7955)
W:     at android.app.Activity.performCreate(Activity.java:7944)
W:     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1307)
W:     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3423)
W:     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3595)
W:     at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:83)
W:     at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135)
W:     at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95)
W:     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2147)
W:     at android.os.Handler.dispatchMessage(Handler.java:107)
W:     at android.os.Looper.loop(Looper.java:237)
W:     at android.app.ActivityThread.main(ActivityThread.java:7811)
W:     at java.lang.reflect.Method.invoke(Native Method)
W:     at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493)
W:     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1076)

1) 为什么我不能在里面写字? 2) 有没有图书馆可以为我做到这一点?

【问题讨论】:

  • Android Q 或 10 ?
  • Android 10。几天前我收到了更新
  • 您能否也发布您所拥有的完整错误日志?
  • 你可以在这里阅读,最近几个月该目录在 Q 下不可用/不可写。
  • 嗯....有什么明确的方法可以让我做我想做的事...??只是写在用户可以访问的文件中

标签: android file fileoutputstream logfile


【解决方案1】:

添加<application android:requestLegacyExternalStorage="true" ... > 在你体现。这是android Q中的新事物。 为了更好的答案检查这个:https://stackoverflow.com/a/56821320/11475673

【讨论】:

    猜你喜欢
    • 2012-01-16
    • 1970-01-01
    • 2013-01-20
    • 2010-12-17
    • 2019-01-08
    • 2012-04-06
    • 2023-03-31
    • 2015-03-19
    • 1970-01-01
    相关资源
    最近更新 更多