Android 输出本地日志文件

本地文件日志输入,制约大小、时限

java库

arduino 复制代码
dependencies {
  implementation 'org.slf4j:slf4j-api:2.0.7'
  implementation 'com.github.tony19:logback-android:3.0.0'
  testImplementation 'ch.qos.logback:logback-classic:1.2.11'
}

configurations.testImplementation {
  exclude module: 'logback-android'
}

logback.xml配置

文件路径的配置

xml 复制代码
<!--    可以这样写-->
<property name="LOG_DIR" value="/storage/emulated/0/A_log" />
<!--    也可以这样写-->
<property name="LOG_DIR" value="${EXT_DIR:-${DATA_DIR}}/B_Log" />
 

日志级别控制

在logback.xml中修改可以控制日志级别:

  • DEBUG:所有日志(开发环境)

  • INFO:及以上级别(生产环境推荐)

  • WARN:警告及以上

  • ERROR:仅错误

Timber

arduino 复制代码
    dependencies {
      implementation 'com.jakewharton.timber:timber:5.0.1'
    }

一个日志框架,可以转发。搭桥转接更方便使用,如此就不需要在每个类中 LoggerFactory.getLogger()。 节省不少重复代码。

在java中调用kotlin

kotlin 复制代码
    /**
 * Slf4jTree是一个Timber的树(Tree)实现,用于将Timber日志输出重定向到SLF4J日志框架。它通过重写DebugTree的log方法,根据日志优先级将日志消息发送到相应的SLF4J日志级别。
 * 避免每次都要在使用类中get.logger()实例
 */
class Slf4jTree : DebugTree() {

    override fun log(priority: Int, tag: String?, message: String, t: Throwable?) {
       val  logger  = LoggerFactory.getLogger(tag)//timber会自动生成tag,一般是类名
        when (priority) {
            Log.VERBOSE -> logger.trace("{}", message, t)
            Log.DEBUG -> logger.debug("{}", message, t)
            Log.INFO -> logger.info("{}", message, t)
            Log.WARN -> logger.warn("{}", message, t)
            Log.ERROR, Log.ASSERT -> logger.error("{}", message, t)
        }
    }
}
    
object TimberUtils {

    @JvmStatic
    fun configTimber() {
        Timber.plant(Slf4jTree())//如果直接在java类中.plan(DebugTree()),IDE会报错警告,这是兼容问题导致。
    }

}
    
    

初始化

java 复制代码
    public class BaseApp extends Application {

    @Override
    public void onCreate() {
        super.onCreate();

        TimberUtils.configTimber();//Timber不能直接在java类中使用,因此间接使用。
    }
}
相关推荐
猩猩程序员4 分钟前
Pretext:一个绕过 DOM 的纯 JavaScript 排版引擎
前端
竹林8184 分钟前
从“连接失败”到丝滑登录:我用 ethers.js 连接 MetaMask 的完整踩坑实录
前端·javascript
神舟之光6 分钟前
jwt权限控制简单总结(乡村意见簿-vue-express-mongdb)
前端·vue.js·express
铭毅天下18 分钟前
EasySearch Rules 规则语法速查手册
开发语言·前端·javascript·ecmascript
GISer_Jing29 分钟前
AI Agent操作系统架构师:Harness Engineer解析
前端·人工智能·ai·aigc
英俊潇洒美少年38 分钟前
css中专门用来提升渲染性能、减少重排重绘的属性
前端·css
天若有情6731 小时前
前端HTML精讲01:别再乱 div 一把抓,吃透语义化标签才是进阶第一步
前端·html
Highcharts.js1 小时前
React 开发者的图表库生态:Highcharts React
前端·react.js·前端框架
阿部多瑞 ABU1 小时前
文明文化悖论
前端·人工智能·ai写作
钛态1 小时前
Flutter 三方库 react 泛前端核心范式框架鸿蒙原生层生态级双向超能适配:跨时空重塑响应式单向数据流拓扑与高度精密生命周期树引擎解耦视图渲染控制中枢(适配鸿蒙 HarmonyOS ohos)
前端·flutter·react.js