LOG4J 在安卓

2022-09-04 01:59:34

我有一个包含大量文件的Java项目,它使用LOG4J。现在我正在尝试将其移植到Android平台。是否可以按原样重用代码,并调用 LOG4J 函数?

目前的理解:

  1. 属性配置不起作用(Bean 依赖项)
  2. 我尝试使用LOG4J for Android和SL4J Lib。没有成功。

加工。但没有用

org.apache.log4j.Logger root = org.apache.log4j.Logger.getRootLogger();
final SocketAppender appender = new SocketAppender("192.168.123.123", 3333);
root.addAppender(appender);

// SLF4J - Not working
org.slf4j.Logger logger;
logger = LoggerFactory.getLogger(MyClass.class); 

// LOG4J for Android - Not working
ConfigureLog4J.configure();
logger = Logger.getLogger( MyClass.class );

我错过了什么吗?指向任何工作示例的指针?


答案 1

通过使用android-logging-log4j.jar解决。

下面是示例代码:

public class ALogger {
    public static org.apache.log4j.Logger getLogger(Class clazz) {
        final LogConfigurator logConfigurator = new LogConfigurator();
        logConfigurator.setFileName(Environment.getExternalStorageDirectory().toString() + File.separator + "log/file.log");
        logConfigurator.setRootLevel(Level.ALL);
        logConfigurator.setLevel("org.apache", Level.ALL);
        logConfigurator.setUseFileAppender(true);
        logConfigurator.setFilePattern("%d %-5p [%c{2}]-[%L] %m%n");
        logConfigurator.setMaxFileSize(1024 * 1024 * 5);
        logConfigurator.setImmediateFlush(true);
        logConfigurator.configure();
        Logger log = Logger.getLogger(clazz);
        return log;
    }
}

在代码中,替换以下行:

PropertyConfigurator.configure(MY_PROP_FILE);
logger = Logger.getLogger( MyClaZZ.class );

跟:

logger = ALogger.getLogger(MyClazz.class);

答案 2

我的回答,这提出了一种更面向未来和横向思维的方法;-)。

我自己使用android-logging-log4j有一段时间了,但它在dexing时引起了大量的警告(实际上看起来像错误)。

log4j jar中还有很多不必要的东西,比如Chainsaw日志记录UI(用Swing编写,因此在Android上毫无用处)。

我已通过 https://github.com/tony19/logback-android 切换到日志。到目前为止,我很高兴。构建时不再有大量垃圾邮件。

另外,看起来log4j 1.x不再开发,看看 https://github.com/apache/log4j/tree/trunk - 上一次提交很多年前。

而logback似乎是继任者。


推荐