[英]Logback-android: Log not getting writen to a file
尝试使用logback-android重定向日志消息,以便可以将消息保存在文件中。 但是,它不会保存到文件中。
这是我的logback.xml文件configration,它存储在我的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>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %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卡内存中。
在清单中添加了用户权限,用于在SD卡中写入日志
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
我在这个配置中遗漏了一些东西,因为我在logcat中没有看到任何配置错误的错误或消息。 有人可以帮助我吗?
对于Android 6+您必须在应用程序的设置中手动定义权限 。 否则,即使您在manifest.xml中授予WRITE_EXTERNAL_STORAGE权限,也不允许回写到外部存储。
我从这里拿了解决方案。
对我而言,Nija在这个问题上的第一个评论就解决了这个问题。
我的文件标签现在看起来像这样:
<file>/sdcard/Android/data/[my-package-from-AndroidManifest]/logs.log</file>
奇怪的是,logs.log文件出现在给定路径下的内部存储上(没有/ sdcard /)。
我的手机运行Android 6.0.1,如果相关的话。
总结我的答案是尝试上面的文件路径并检查内部存储,以防其他答案不起作用。
更新 :
只是想在计算机上打开日志文件,但找不到它。 我仍然可以通过手机本身的任何存储访问应用程序(例如文件指令器)找到它。 但是当看到与PC完全相同的文件夹时,它就不存在了。 因此,当它对您来说足够好时,请使用存储访问应用程序进行检查。
您是否尝试将配置添加到AndroidManifest.xml?
示例清单(来自此链接 ):
<?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>%logger{0}</pattern>
</tagEncoder>
<encoder>
<pattern>[ %thread ] %msg%n</pattern>
</encoder>
</appender>
<root level="WARN" >
<appender-ref ref="LOGCAT" />
</root>
</configuration>
</logback>
</manifest>
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.