文档章节

log4j的使用

乐在克里特
 乐在克里特
发布于 2017/02/24 11:22
字数 603
阅读 30
收藏 0

基本步骤:

1、导入包
2、创建Logger对象
 //创建Logger对象
 public static final Logger logger = Logger.getLogger(UserDao.class);
3、编写相应的日志
  /**
   * 可以为日志设定不同的级别,在log4j中
   * debug<info<warn<error<fatal
   */
  logger.debug("添加了用户信息");
  logger.info("添加了用户信息");
  logger.warn("添加了用户信息");
  logger.error("添加了用户信息");
  logger.fatal("添加了用户信息");
4、编写日志的配置文件,以此说明日志的显示方式和级别(在src中创建log4j.properties文件)
   4.1、首先创建Append
   log4j.appender.stout=org.apache.log4j.ConsoleAppender
        创建了一个appender名称叫做stout,使用的类型是ConsoleAppender
   4.2、说明展示的布局
   log4j.appender.stout.layout=org.apache.log4j.PatternLayout
        说明Appender使用哪种布局来展示,常用的是PatternLayout来展示
   4.3、说明通过什么样的格式来完成展示
   log4j.appender.stout.layout.ConversionPattern=[%p](%l)-->%m(%d)
    使用的格式是[什么级别的日志](日志的发生地)-->日志信息(日志的时间)
5、在什么时候输出日志
log4j.rootLogger=DEBUG, stout
rootLogger是根目录的Logger,每一个项目的classpath就是根目录,只要运行到输出日志的位置,并且日志的级别大于DEBUG就会输出。rootLogger表示的就是执行的任意一个类只要有大于DEBUG的日志就会输出,会调用stout这个Appender输出。

 

配置文件及代码

(1)本操作中的log4j.properties:

log4j.appender.stout=org.apache.log4j.ConsoleAppender
log4j.appender.stout.layout=org.apache.log4j.PatternLayout
log4j.appender.stout.layout.ConversionPattern=[%p](%l)-->%m(%d)%n

#log4j.appender.fout=org.apache.log4j.FileAppender

#log4j.appender.fout = org.apache.log4j.DailyRollingFileAppender
#log4j.appender.fout.datePattern='.'yyyy-MM-dd

log4j.appender.fout = org.apache.log4j.RollingFileAppender
log4j.appender.fout.maximumFileSize = 200
log4j.appender.fout.maxBackupIndex = 100
#there are some tips that you should be careful.!!!!!!!!!

#log4j.appender.fout.file = d:/test/log/user.log

log4j.appender.fout.file = ${LOG_DIR}/user.log
log4j.appender.fout.layout=org.apache.log4j.PatternLayout
log4j.appender.fout.layout.ConversionPattern=[%p](%l)-->%m%n

#rootLogger\u7684\u521b\u5efa
log4j.rootLogger=FATAL, stout
#log4j.logger.test = WARN,fout

log4j.logger.org.zttc.itat.service = DEBUG,fout

 

(2)某个类(UserDao/UserService)需要使用log4j来记录信息

package org.zttc.itat.dao;

import org.apache.log4j.Logger;

public class UserDao {
	//创建Logger对象
	public static final Logger logger = Logger.getLogger(UserDao.class);
	public void add() {
		/**
		 * 可以为日志设定不同的级别,在log4j中
		 * debug<info<warn<error<fatal
		 */
		logger.debug("添加了用户信息");
		logger.info("添加了用户信息");
		logger.warn("添加了用户信息");
		logger.error("添加了用户信息");
		logger.fatal("添加了用户信息");
	}
}

 

(3)测试类调用时:

package org.zttc.itat.test;

import org.zttc.itat.dao.UserDao;
import org.zttc.itat.service.UserService;

public class TestLog {
   public static void main(String[] args) {
	String url = UserService.class.getClassLoader().getResource("").getPath();
	System.out.println("class_path:" + url);
	url = url + "log";
	System.setProperty("LOG_DIR", url);
	UserDao ud = new UserDao();
	ud.add();
	UserService us = new UserService();
	us.add();
   }
}

 

以上为学习教程中整理的代码和说明。

 

此外,查看更多log4j.properties详解及配置步骤:

http://blog.csdn.net/edward0830ly/article/details/8250412

还有更加详细的教程:(有点长,但是很详细)

http://www.codeceo.com/article/log4j-usage.html

 

© 著作权归作者所有

共有 人打赏支持
乐在克里特
粉丝 15
博文 268
码字总数 394729
作品 0
杭州
程序员

暂无文章

DES/3DES(TripleDES)加密、解密测试数据

以下结果经 PHP+openssl及VB.NET验证,ECB模式。 PHP 7.0.10 (cli) (built: Aug 18 2016 09:48:53) ( ZTS ) OpenSSL Library Version: OpenSSL 1.0.1t 3 May 2016 VB.net 2003 ****** DES(S......

SamXIAO
28分钟前
1
0
Java11的新特性

Java语言特性系列 Java5的新特性 Java6的新特性 Java7的新特性 Java8的新特性 Java9的新特性 Java10的新特性 Java11的新特性 Java12的新特性 序 本文主要讲述一下Java11的新特性 版本号 java...

go4it
29分钟前
3
0
Maven常用命令及相关笔记

Maven常用命令 dos指令 4. 编译源代码: mvn compile 6. 运行测试: mvn test 8. 打包: mvn package 9. 在本地Repository中安装jar: mvn install 10. 清除产生的项目: mvn clean 4. 运行项...

颖伙虫
36分钟前
1
0
swagger2.2.2 与 spring cloud feign冲突 导致服务请求报空

swagger2.2.2 与 spring cloud feign冲突 Java代码 Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'com.choosefine.web.console.ar......

泉天下
39分钟前
1
0
设计模式之 明确责任 观察者模式 状态模式 责任链模式

观察者模式是任务分发的一种模式。 如果认为我们设计的系统的各个模块(或子系统)的最终目的是完成共同任务,那么这个任务如何分配到多个模块的就是我们遇到的第一个问题。简单设计场合我们...

backbye
43分钟前
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部