Logback-android:日志未写入文件
Posted
技术标签:
【中文标题】Logback-android:日志未写入文件【英文标题】:Logback-android: Log not getting writen to a file 【发布时间】:2015-03-19 12:25:19 【问题描述】:尝试使用 logback-android 重定向日志消息,以便可以将消息保存在文件中。但是,它不会被保存到文件中。
这是我的 logback.xml 文件配置,它存储在我的 Android Studio 中的 src/main/assets 下
<configuration debug="true">
<!-- Create a file appender for a log in the application's data directory -->
<appender name="FILE" class="ch.qos.logback.classic.android.FileAppender">
<file>/data/com.test.equa/files/log/foo.log</file>
<encoder>
<pattern>%dHH:mm:ss.SSS [%thread] %-5level %logger36 - %msg%n</pattern>
</encoder>
</appender>
<!-- Write INFO (and higher-level) messages to the log file -->
<root level="INFO">
<appender-ref ref="FILE" />
</root>
</configuration>
这是我启动日志记录的一段代码。
@Override
public void onCreate()
super.onCreate();
loadData();
Logger log = LoggerFactory.getLogger(MyActivity.class);
log.error("Application Data setup in progress");
问题:我继续在 logcat 中看到这些消息,但我希望它们存储在我的 android sd 卡内存中。
在manifest中添加用户权限,用于将日志写入sd卡
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
我是否在这个配置中遗漏了一些东西,因为我在我的 logcat 中也没有看到任何配置错误的错误或消息。有人可以帮我吗
【问题讨论】:
我不确定,因此不是答案;但路径<file>/data/com.test.equa/files/log/foo.log</file>
不是外部存储;所以提到的许可应该无关紧要。也可能是/data/data/PACKAGE...
。如果您想写入 SD 卡,路径应该类似于 /sdcard/Android/PACKAGE/....
,然后权限很重要。这只是我的想法;因此,与其尝试回答,不如说是“我接下来要尝试什么”。 :)
感谢 Nija 指出这一点。我也检查了包目录,日志文件也不存在。再次感谢您的回复和指出..
您在 logcat 中究竟看到了什么消息?
@superuser 我看到了正常的日志消息。没有警告或错误
根据您的示例 logback.xml,您应该在 logcat 中看不到来自您的应用程序的消息(“正在进行应用程序数据设置”),因为您没有 LogcatAppender
。您在 logcat 中看到的消息文本究竟是什么?
【参考方案1】:
对于 Android 6+,您必须为您的应用程序定义 permissions manually in settings。否则即使你在 manifest.xml 中授予WRITE_EXTERNAL_STORAGE 权限,logback 也不会被允许写入外部存储。
我从here那里得到了解决方案。
【讨论】:
很好奇(有点跑题了)——你如何从真实设备上获取文件 appender 记录到的 html 文件的副本?我不认为你可以?您必须使用 DDMS 从 AndroidStudio 模拟器中检索它吗? 这是一个很好的问题,但我不知道答案 - 我切换回 .Net 模块。你应该在公共论坛上“”。祝你好运。 当您开始开发应用但仍不使用 UI 请求权限时,这一点尤为重要。【参考方案2】:对我来说,Nija 对这个问题的第一条评论就解决了这个问题。
我的文件标签现在看起来像这样:
<file>/sdcard/Android/data/[my-package-from-AndroidManifest]/logs.log</file>
奇怪的想法是,logs.log 文件出现在给定路径下的我的内部存储中(没有 /sdcard/)。
我的手机运行的是 Android 6.0.1,以防万一。
总结我的答案是尝试上述文件路径并检查内部存储,以防其他答案不起作用。
更新:
只是想打开电脑上的日志文件,但找不到。我仍然可以通过手机本身的任何存储访问应用程序(例如文件指挥官)找到它。但是当查看与 PC 完全相同的文件夹时,它不存在。因此,如果对您来说足够好,请使用存储访问应用程序检查一下。
【讨论】:
添加/sdcard/android/data/
似乎在一开始就有效,但我注意到当我关闭并重新打开我的应用程序时,它不再写入文件;它只是什么都不做。但可能是我做错了什么。
是的,发生在我身上。在 Windows 上看不到文件,但通过智能手机本身的文件管理器,文件就在那里。【参考方案3】:
您是否尝试将配置添加到 AndroidManifest.xml?
清单示例(来自link):
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk
android:minSdkVersion="8"
android:targetSdkVersion="16" />
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<activity
android:name="com.example.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>
</application>
<logback>
<configuration>
<appender
name="LOGCAT"
class="ch.qos.logback.classic.android.LogcatAppender" >
<tagEncoder>
<pattern>%logger0</pattern>
</tagEncoder>
<encoder>
<pattern>[ %thread ] %msg%n</pattern>
</encoder>
</appender>
<root level="WARN" >
<appender-ref ref="LOGCAT" />
</root>
</configuration>
</logback>
</manifest>
【讨论】:
感谢您的回复。我之前确实尝试过,但让我从头开始再试一次,然后会更新 不走运。它使用 Logcat Appender 效果很好,但是如果我用 File Appender 替换它并提供一个文件,它就不起作用。如果我使用代码进行配置,它运行良好。但是为了简化我的应用程序,我希望通过 XML 进行配置。你有任何工作示例代码,你可以分享一下【参考方案4】:就我而言,当我重新启动智能手机时,文件仅在 Windows 文件资源管理器中显示/更新。
强制我使用的更新:
MediaScannerConnection.scanFile(myContext, new String[]new File(Environment.getExternalStorageDirectory(), "logFile.log").toString(), null, null);
【讨论】:
以上是关于Logback-android:日志未写入文件的主要内容,如果未能解决你的问题,请参考以下文章
使用 spdlog (C++) 记录,记录器未将日志写入文件
指定 IP 地址时 syslog NG 未启动,但可作为全部捕获并写入文件设置