Android 如何使用log4j及注意事项

作者:lqh 时间:2023-06-01 07:47:24 

 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中,增加如下设置:


<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

   然后在程序中如下使用:  


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的用法差不多了。

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

来源:http://jackyrong.iteye.com/blog/1694699

标签:Android,log4j
0
投稿

猜你喜欢

  • 使用Jacoco获取 Java 程序的代码执行覆盖率的步骤详解

    2022-07-22 00:25:13
  • 你真的知道Java中对象的销毁吗

    2022-09-14 22:31:38
  • idea手动刷新git分支的详细教程

    2022-04-05 11:53:43
  • Android Studio用genymotion运行后小图标无法显示问题

    2021-08-17 03:00:22
  • C#控制台程序中使用官方依赖注入的实现

    2021-07-12 15:35:09
  • C#深浅拷贝的深入解析

    2023-03-28 18:36:28
  • Android 开发使用PopupWindow实现弹出警告框的复用类示例

    2022-04-07 03:43:42
  • Spring Validation方法实现原理分析

    2023-09-04 17:11:55
  • Android EditText限制输入字符的方法总结

    2023-04-22 03:16:24
  • android开发实现文件读写

    2022-08-03 09:46:18
  • Jmeter分布式压力测试实现过程详解

    2022-03-23 21:32:44
  • java面向对象设计原则之里氏替换原则示例详解

    2023-02-02 05:04:41
  • c#使用windows服务更新站点地图的详细示例

    2021-07-24 10:45:52
  • c#制作类似qq安装程序一样的单文件程序安装包

    2021-07-22 17:13:31
  • Android自定义Notification添加点击事件

    2022-04-06 19:06:30
  • C#中XmlTextWriter读写xml文件详细介绍

    2022-01-26 05:13:48
  • C#操作windows系统进程的方法

    2023-06-09 05:11:45
  • 阿里云OSS域名配置及简单上传的示例代码

    2022-04-08 19:14:32
  • 解析Spring Boot内嵌tomcat关于getServletContext().getRealPath获取得到临时路径的问题

    2023-08-28 07:44:11
  • SpringBoot配置 Druid 三种方式(包括纯配置文件配置)

    2021-06-03 01:41:19
  • asp之家 软件编程 m.aspxhome.com