Android 使用log4j

前言:

 如果要直接在android工程中使用log4j,是有点问题的,会报如下的错:

11-23 09:44:56.947: D/dalvikvm(1585): GC_FOR_MALLOC freed 3278 objects / 311568 bytes in 31ms rejecting opcode 0x21 at 0x000a rejected Lorg/apache/log4j/config/PropertySetter;.getPropertyDescriptor (Ljava/lang/String;)Ljava/beans/PropertyDescriptor; Verifier rejected class Lorg/apache/log4j/config/PropertySetter; Exception Ljava/lang/VerifyError; thrown during Lorg/apache/log4j/LogManager;. Shutting down VM threadid=1: thread exiting with uncaught exception (group=0x400259f8) FATAL EXCEPTION: main java.lang.ExceptionInInitializerError at org.slf4j.impl.Log4jLoggerFactory.getLogger(Log4jLoggerFactory.java:64) at org.slf4j.LoggerFactory.getLogger(LoggerFactory.java:253) at org.slf4j.LoggerFactory.getLogger(LoggerFactory.java:265) ... Caused by: java.lang.VerifyError: org.apache.log4j.config.PropertySetter at org.apache.log4j.PropertyConfigurator.parseAppender(PropertyConfigurator.java:772) at org.apache.log4j.PropertyConfigurator.parseCategory(PropertyConfigurator.java:735) at org.apache.log4j.PropertyConfigurator.configureRootCategory(PropertyConfigurator.java:615) at org.apache.log4j.PropertyConfigurator.doConfigure(PropertyConfigurator.java:502) at org.apache.log4j.PropertyConfigurator.doConfigure(PropertyConfigurator.java:547) at org.apache.log4j.helpers.OptionConverter.selectAndConfigure(OptionConverter.java:483) at org.apache.log4j.LogManager.(LogManager.java:127) ... 20 more 

因此,可以另外多下载一个叫android-logging-log4j的项目,地址在:

http://code.google.com/p/android-logging-log4j/downloads/list,注意,原本的log4j还是需要的。

  在AndroidManifest.xml中,增加如下设置:

 

   然后在程序中如下使用:  

package com.android.myapp;   . import java.io.File;    import org.apache.log4j.Level;    import org.apache.log4j.Logger; . import android.app.Application;    import android.os.Environment;    import de.mindpipe.android.logging.log4j.LogConfigurator;  .   public class MyApplication extends Application {        @Override        public void onCreate() {            super.onCreate();            LogConfigurator logConfigurator = new LogConfigurator();            logConfigurator.setFileName(Environment.getExternalStorageDirectory()                    + File.separator + "MyApp" + File.separator + "logs"                    + File.separator + "log4j.txt");            logConfigurator.setRootLevel(Level.DEBUG);            logConfigurator.setLevel("org.apache", Level.ERROR);            logConfigurator.setFilePattern("%d %-5p [%c{2}]-[%L] %m%n");            logConfigurator.setMaxFileSize(1024 * 1024 * 5);            logConfigurator.setImmediateFlush(true);            logConfigurator.configure();            Logger log = Logger.getLogger(MyApplication.class);            log.info("My Application Created");        }    } 

     现在日志则是以:

Environment.getExternalStorageDirectory() + File.separator + "MyApp" + File.separator + "logs" + File.separator + "log4j.txt
   的方式保存了。其他和log4j的用法差不多了。

 感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

更多相关文章

  1. 箭头函数的基础使用
  2. NPM 和webpack 的基础使用
  3. Python list sort方法的具体使用
  4. 【阿里云镜像】使用阿里巴巴DNS镜像源——DNS配置教程
  5. Android(安卓)PopWindow使用
  6. 迁移到Android(安卓)Studio 3.0
  7. Android(安卓)Launcher3一些默认修改
  8. Android中有关Handler的使用(二)
  9. android中Socket的使用

随机推荐

  1. [置顶] Android入门系列一(Android学习方
  2. Android Studio试用总结
  3. Android AsyncTask解析
  4. Couldn't find meta-data for provider w
  5. .net程序员转战android第二篇---牛刀小试
  6. 理解Android的菜单
  7. Android之MPAndroidChart库使用说明(柱状
  8. Android NFS文件系统挂载遇到的问题解决
  9. Android里面常用的Drawable的使用
  10. android读取keystore证书文件