如何在部署apk后更改android上的logback配置?没有重新编译

时间:2015-03-01 14:53:02

标签: android logback

在常规java中,可以在jar文件夹中放置备用logback.xml文件来更改logback配置,例如更改日志级别。

这是否可以在Android上使用logback-android?

1 个答案:

答案 0 :(得分:0)

是的,这是可能的。除了logback.xml中的常规位置外,logback-android还允许指定备用/可选位置。

在下面的示例配置中,logback-android仅在文件存在时才加载logback-debug.xml文件。否则,它会加载logback-release.xml

资产/ logback.xml:

<configuration>
  <includes>
    <!-- logback picks first configuration found in the following list -->
    <include resource="assets/config/logback-debug.xml"/>
    <include resource="assets/config/logback-release.xml"/>
  </includes>
</configuration>

资产/配置/的logback-debug.xml

<configuration>
  <appender name="file" class="ch.qos.logback.classic.android.LogcatAppender">
    <encoder>
      <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
    </encoder>
  </appender>

  <root level="DEBUG">
    <appender-ref ref="LOGCAT" />
  </root>
</configuration>

资产/配置/的logback-release.xml

<configuration>
  <appender name="file" class="ch.qos.logback.core.FileAppender">
    <file>/data/data/com.example/files/log/foo.log</file>
    <encoder>
      <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
    </encoder>
  </appender>

  <root level="INFO">
    <appender-ref ref="file" />
  </root>
</configuration>