android - 将日志写入txt文件android
问题描述
我有一个应用程序和一些事件,我想将它们保存在下载中的 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)有没有图书馆可以为我做到这一点?
解决方案
添加<application android:requestLegacyExternalStorage="true" ... >
你的清单。这是android Q中的新事物。为了更好的答案,请检查:https ://stackoverflow.com/a/56821320/11475673
推荐阅读
- node.js - 为什么实时数据库更新有时会因令牌更新的爆发而延迟?
- twitter-bootstrap - 如何在 BOOTSTRAP 5 上推拉列?
- python - __getitem__ 中使用的 Python 参数?
- sql - BigQuery SQL 用户代理检测
- android - 自动竞争在 Android Studio 中不起作用
- python - 日期不等于今天
- python - 将类对象转换为 Json(带有日期时间字段)-TypeError:日期时间类型的对象不是 JSON 可序列化的
- javascript - 将 Javascript 中的 React.js 元素数组存储到某个文件或任何存储中,以便以后使用
- flutter - 从 Future 函数返回字符串
- selenium - http登录请求 - selenium webdriver