- 浏览: 101980 次
- 性别:
- 来自: 上海
文章分类
最新评论
-
heihei2005:
灰常好!谢谢!
进行需求调研时的注意事项 -
yinzhiyan:
就这么点啊
数据结构 -
jeho0815:
这也太简陋了吧!。。。。
Prototype模式(原形模式) -
shanghui_12:
功能是挺齐备的,能否给个测试地址看看?
截至到2008的圣诞节,saas平台的体系结构已现端倪 -
sdh5724:
amoeba 马上要上线了, 我们测试了1个多月了。 基本稳定 ...
saas中分布式DB存储问题--草稿版
1 关于log4j的文章---粗略看了一遍,不错!
出处给忘了好像是下面这个:
http://dev2dev.bea.com.cn/bbs/servlet/D2DServlet/download/124-14026-77822-650/深入学习Log4J.pdf
深入学习Log4J
李翔
内容:
一,Log4J配置文件的学习
二,Log4J数据库
三,Log4J封装
一,Log4J配置文件学习:
Log4j支持两种配置文件格式,一种是XML格式的文件,一种是Java特性文件(键=值).
下面我们首先介绍使用Java特性文件做为配置文件的方法:
分析一个配置文件log4j.properties
log4j.rootCategory=debug, stdout, R
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
# Pattern to output the caller's file name and line number.
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] (%F:%L) - %m%n
log4j.appender.R=org.apache.log4j.RollingFileAppender
log4j.appender.R.File=example.log
log4j.appender.R.MaxFileSize=100KB
# Keep one backup file
log4j.appender.R.MaxBackupIndex=1
log4j.appender.R.layout=org.apache.log4j.PatternLayout
log4j.appender.R.layout.ConversionPattern=%p %t %c - %m%n
说明:
①log4j.rootCategory = [ level ] , appenderName, appenderName,
其中,level 是日志记录的优先级,分为OFF,FATAL,ERROR,WA R N,INFO,DEBUG,
ALL或者您定义的级别.Log4j建议只使用四个级别,优先级从高到低分别是ERROR,
WA R N,INFO,DEBUG.通过在这里定义的级别,您可以控制到应用程序中相应级别的日
志信息的开关.比如在这里定义了INFO级别,则应用程序中所有DEBUG级别的日志信息
将不被打印出来.appenderName就是指定日志信息输出到哪个地方.您可以同时指定多个
输出目的地.
②配置日志信息输出目的地Appender,其语法为
log4j.appender.appenderName = fully.qualified.name.of.appender.class
log4j.appender.appenderName.option1 = value1
log4j.appender.appenderName.option = valueN
其中,Log4j提供的appender有以下几种:
org.apache.log4j.ConsoleAppender(控制台),
org.apache.log4j.FileAppender(文件),
org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件),
org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件),
org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)
③配置日志信息的格式(布局),其语法为:
log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class
log4j.appender.appenderName.layout.option1 = value1
log4j.appender.appenderName.layout.option = valueN
其中,Log4j提供的layout有以下几种:
org.apache.log4j.HTMLLayout(以HTML表格形式布局),
org.apache.log4j.PatternLayout(可以灵活地指定布局模式),
org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),
org.apache.log4j.TTCCLayout(包含日志产生的时间,线程,类别等等信息)
④Log4J采用类似C语言中的printf函数的打印格式格式化日志信息,打印参数如下:
%m 输出代码中指定的消息
%p 输出优先级,即DEBUG,INFO,WA R N,ERROR,FATAL
%r 输出自应用启动到输出该log信息耗费的毫秒数
%c 输出所属的类目,通常就是所在类的全名
%t 输出产生该日志事件的线程名
%n 输出一个回车换行符,Windows平台为"\r\n",Unix平台为"\n"
%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,
比如:%d{yyy MMM dd HH:mm:ss,SSS},输出类似:2002年10月18日 22:10:28,921
%l 输出日志事件的发生位置,包括类目名,发生的线程,以及在代码中的行数.
对上面log4j.properties配置文件的一个应用;
作者: songjizheng 2006-12-29 17:51 回复此发言
--------------------------------------------------------------------------------
2 关于log4j的文章---粗略看了一遍,不错!
package log4j;
import org.apache.log4j.*;
// How to use log4j
public class TestLogging {
// Initialize a logging category. Here, we get THE ROOT CATEGORY
//static Category cat = Category.getRoot();
// Or, get a custom category
static Category cat = Category.getInstance(TestLogging.class.getName());
// From here on, log away! Methods are: cat.debug(your_message_string),
// cat.info(...), cat.warn(...), cat.error(...), cat.fatal(...)
public static void main(String args[]) {
// Try a few logging methods
PropertyConfigurator.configure ( "log4j.properties" ) ;
cat.debug("Start of main()");
cat.info("Just testing a log message with priority set to INFO");
cat.warn("Just testing a log message with priority set to WARN");
cat.error("Just testing a log message with priority set to ERROR");
cat.fatal("Just testing a log message with priority set to FATAL");
// Alternate but INCONVENIENT form
cat.log(Priority.DEBUG, "Calling init()");
new TestLogging().init();
}
public void init() {
java.util.Properties prop = System.getProperties();
java.util.Enumeration enum = prop.propertyNames();
cat.info("***System Environment As Seen By Java***");
cat.debug("***Format: PROPERTY = VALUE***");
while (enum.hasMoreElements()) {
String key = (String) enum.nextElement();
cat.info(key + " = " + System.getProperty(key));
}
}
}
xml格式的log4j配置文件概述
xml格式的log4j配置文件需要使用org.apache.log4j.html.DOMConfigurator.configure()方法来
读入.对xml文件的语法定义可以在log4j的发布包中找到:org/apache/log4j/xml/log4j.dtd.
Xml的一个配置文件:sample1.xml
说明:
①xml配置文件的头部包括两个部分:xml声明和dtd声明.头部的格式如下:
②log4j:configuration (root element)
xmlns:log4j [#FIXED attribute]: 定义log4j的名字空间,取定值"http://jakarta.apache.org/log4j/"
appender [* child] : 一个appender子元素定义一个日志输出目的地
logger [* child] : 一个logger子元素定义一个日志写出器
root [ child] : root子元素定义了root logger
源代码:
package exampleslog4j.xml;
import org.apache.log4j.xml.DOMConfigurator;
import org.apache.log4j.Category;
import java.net.*;
public class XMLSample {
static Category cat = Category.getInstance(XMLSample.class.getName());
public
static
void main(String argv[]) {
if(argv.length == 1)
init(argv[0]);
else
Usage("Wrong number of arguments.");
sample();
}
static
void Usage(String msg) {
System.err.println(msg);
System.err.println( "Usage: java " + XMLSample.class.getName() +
"configFile");
System.exit(1);
}
static
void init(String configFile) {
DOMConfigurator.configure(configFile);
}
static
void sample() {
int i = -1;
Category root = Category.getRoot();
cat.debug("Message " + ++i);
cat.warn ("Message " + ++i);
cat.error("Message " + ++i);
Exception e = new Exception("Just testing");
cat.debug("Message " + ++i, e);
}
}
执行后的效果:
2004-05-24 22:07:28,352 DEBUG [main] xml.XMLSample (XMLSample.java:55) - Message 0
2004-05-24 22:07:28,352 WARN [main] xml.XMLSample (XMLSample.java:56) - Message 1
作者: songjizheng 2006-12-29 17:51 回复此发言
--------------------------------------------------------------------------------
3 关于log4j的文章---粗略看了一遍,不错!
2004-05-24 22:07:28,362 ERROR [main] xml.XMLSample (XMLSample.java:57) - Message 2
2004-05-24 22:07:28,362 DEBUG [main] xml.XMLSample (XMLSample.java:59) - Message 3
java.lang.Exception: Just testing
at exampleslog4j.xml.XMLSample.sample(XMLSample.java:58)
at exampleslog4j.xml.XMLSample.main(XMLSample.java:36)
二,Log4J对数据库的操作:
其目的就是把日志信息写入数据库以方便开发人员和测试人员查询.
下面是写入数据库的配置文件:log4j.properties
log4j.appender.DATABASE=org.apache.log4j.jdbc.JDBCAppender
log4j.appender.DATABASE.URL=jdbc:oracle:thin:@192.168.0.1:1521:siemen
log4j.appender.DATABASE.driver= oracle.jdbc.driver.OracleDriver
log4j.appender.DATABASE.user=system
log4j.appender.DATABASE.password=css12345
log4j.appender.DATABASE.sql=INSERT INTO LOG4J (Message) VALUES ('[framework] %d
- %c -%-4r [%t] %-5p %c %x - %m%n')
log4j.appender.DATABASE.layout=org.apache.log4j.PatternLayout
log4j.appender.DATABASE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t]
%-5p %c %x - %m%n
log4j.appender.A1=org.apache.log4j.DailyRollingFileAppender
log4j.appender.A1.File=SampleMessages.log4j
log4j.appender.A1.DatePattern=yyyyMMdd-HH'.log4j'
log4j.appender.A1.layout=org.apache.log4j.xml.XMLLayout
对其应用的源文件:
package database.servlet;
import java.io.File;
import java.io.LineNumberReader;
import java.io.FileReader;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.util.Vector;
import java.sql.Driver;
import java.sql.DriverManager;
// import servlet packages
import javax.servlet.http.HttpServlet;
import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
// import log4j packages
import org.apache.log4j.Logger;
import org.apache.log4j.PropertyConfigurator;
public class SetupServlet extends HttpServlet{
public void init(ServletConfig config) throws ServletException{
super.init(config);
// first thing to do, is to set up the Driver that we might be using
// in case of JDBCAppender
try{
//Driver d =(Driver)(Class.forName("org.gjt.mm.mysql.Driver").newInstance());
Driver d = (Driver)(Class.forName("oracle.jdbc.driver.OracleDriver").newInstance());
DriverManager.registerDriver(d);
//加载JDBC驱动程序,当准备将日志记录到数据库的时候可以使用
}catch(Exception e){ System.err.println(e); }
// next load up the properties
//启动时从web.xml中获得配置文件的信息
String props = config.getInitParameter("props");
if(props == null || props.length() == 0 ||
!(new File(props)).isFile()){
System.err.println(
"ERROR: Cannot read the configuration file. " +
"Please check the path of the config init param in web.xml");
throw new ServletException();
}
}
public void destroy(){
super.destroy();
}
}
三,Log4J的封装:
配置文件:log4j.properties
log4j.rootLogger=DEBUG, A2, A1
log4j.appender.A2=org.apache.log4j.RollingFileAppender
log4j.appender.A2.File=C:\develop\log\error.log
log4j.appender.A2.Append=true
log4j.appender.R.MaxFileSize=10000KB
log4j.appender.A2.layout=org.apache.log4j.PatternLayout
作者: songjizheng 2006-12-29 17:51 回复此发言
--------------------------------------------------------------------------------
4 关于log4j的文章---粗略看了一遍,不错!
log4j.appender.A2.layout.ConversionPattern=[%-5p][%t] %d{yyyy-MM-dd
HH:mm:ss,SSS} message:%m%n
log4j.appender.A1=org.apache.log4j.ConsoleAppender
log4j.appender.A1.layout=org.apache.log4j.PatternLayout
#Pattern to output the caller's file name and line number.
#log4j.appender.stdout.layout.ConversionPattern=%5p [%t] (%F:%L) - %m%n
# Print the date in ISO 8601 format
log4j.appender.A1.layout.ConversionPattern=%d [%t] %-5p - %m%n
EncapsulationLog4J.java //Log4j的实现类
package com.cn.lx;
/**
*
Title:
*
Description:
*
Copyright: Copyright © 2004 lixiang
*
Company:http://www.css.com.cn/
* @author lixiang
* @version 1.0
*/
import org.apache.log4j.*;
import java.io.*;
import java.util.*;
/**
* @author Administrator
*
* To change the template for this generated type comment go to
* Window>Preferences>Java>Code Generation>Code and Comments
*/
public class EncapsulationLog4J
{
public static final String PROFILE = "log4j.properties";
/**
* Holds singleton instance
*/
private static EncapsulationLog4J impl;
static
{
impl = new EncapsulationLog4J();
}
private Logger log4j;
/**
* prevents instantiation
*/
private EncapsulationLog4J()
{
log4j = LogManager.getLogger(EncapsulationLog4J.class);
try
{
Properties pro = new Properties();
InputStream is = getClass().getResourceAsStream(PROFILE);
pro.load(is);
PropertyConfigurator.configure(pro);
}
catch(IOException e)
{
BasicConfigurator.configure();
e.printStackTrace();
}
}
public void log(String level,Object msg)
{
log(level,msg,null);
}
public void log(String level,Throwable e)
{
log(level,null,e);
}
public void log(String level,Object msg,java.lang.Throwable e)
{
if(log4j != null)
{
log4j.log((Priority)Level.toLevel(level),msg,e);
}
}
/**
* Singleton Pattern
*/
static public EncapsulationLog4J getInstance()
{
return impl;
}
}
Log.java //记录Log使用类
package com.cn.lx;
/**
*
Title:
*
Description:
*
Copyright: Copyright © 2004 lixiang
*
Company: http://www.css.com.cn/
* @author lixiang
* @version 1.0
*/
public class Log
{
private static EncapsulationLog4J log = EncapsulationLog4J.getInstance();
/**
*
*/
public Log()
{
//super();
}
public static void logError(String msg)
{
log.log("ERROR",msg);
}
public static void logError(Throwable e)
{
log.log("ERROR",null,e);
}
public static void logWarn(String msg)
{
log.log("WARN",msg);
}
public static void logWarn(Throwable e)
{
log.log("WARN",null,e);
}
public static void logInfo(String msg)
{
log.log("INFO",msg);
}
public static void logInfo(Throwable e)
{
log.log("INFO",null,e);
}
public static void logDebug(String msg)
{
log.log("DEBUG",msg);
}
public static void logDebug(Throwable e)
{
log.log("DEBUG",null,e);
}
}
TestLog.java //调用Log类
package com.cn.lx;
public class TestLog{
public static void main(String[] args) {
Log test = new Log();
test.logDebug("DEBUG");
test.logInfo("INFO");
test.logWarn("WARN");
test.logError("ERROR");
try
{
int i = Integer.parseInt("lixiang");
}catch(Exception e)
{
test.logDebug(e.toString());
test.logInfo(e.toString());
test.logWarn(e.toString());
test.logError(e.toString());
}
}
}
执行后的日志信息:
2004-05-26 21:16:16,474 [main] DEBUG - DEBUG
2004-05-26 21:16:16,484 [main] INFO - INFO
2004-05-26 21:16:16,484 [main] WARN - WARN
2004-05-26 21:16:16,484 [main] ERROR - ERROR
2004-05-26 21:16:16,484 [main] DEBUG - java.lang.NumberFormatException: For input string:
"lixiang"
2004-05-26 21:16:16,484 [main] INFO - java.lang.NumberFormatException: For input string:
"lixiang"
2004-05-26 21:16:16,484 [main] WARN - java.lang.NumberFormatException: For input string:
"lixiang"
2004-05-26 21:16:16,484 [main] ERROR - java.lang.NumberFormatException: For input string:
"lixiang"
注:使用此方法封装Log4j的操作,可以使记录日志变得更方便.唯一不足的是无法返回当
前类的相关信息.
最后说明:
关于对日志进行处理的技术有好多,如JDK 1.4 logging,Avalon LogKit,Jakarta 的Log4J
,Jakarta的Commons-Logging等.做的最好的是Commons-Logging.下面对其做一介绍:
The Jakarta Commons Logging (JCL) provides a Log interface that is
intended to be both light-weight and independent of numerous logging
toolkits. It provides the middleware/tooling developer with a simple logging
abstraction, that allows the user (application developer) to plug in a specific
logging implementation.
The Jakarta Commons Logging provides a Log interface with
thin-wrapper implementations for other logging tools, including
Log4J , Avalon LogKit , the Avalon Framework's logging
infrastructure, JDK 1.4, and an implementation of JDK 1.4 logging
APIs (JSR-47) for pre-1.4 systems. The interface maps closely to
Log4J and LogKit.
出处给忘了好像是下面这个:
http://dev2dev.bea.com.cn/bbs/servlet/D2DServlet/download/124-14026-77822-650/深入学习Log4J.pdf
深入学习Log4J
李翔
内容:
一,Log4J配置文件的学习
二,Log4J数据库
三,Log4J封装
一,Log4J配置文件学习:
Log4j支持两种配置文件格式,一种是XML格式的文件,一种是Java特性文件(键=值).
下面我们首先介绍使用Java特性文件做为配置文件的方法:
分析一个配置文件log4j.properties
log4j.rootCategory=debug, stdout, R
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
# Pattern to output the caller's file name and line number.
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] (%F:%L) - %m%n
log4j.appender.R=org.apache.log4j.RollingFileAppender
log4j.appender.R.File=example.log
log4j.appender.R.MaxFileSize=100KB
# Keep one backup file
log4j.appender.R.MaxBackupIndex=1
log4j.appender.R.layout=org.apache.log4j.PatternLayout
log4j.appender.R.layout.ConversionPattern=%p %t %c - %m%n
说明:
①log4j.rootCategory = [ level ] , appenderName, appenderName,
其中,level 是日志记录的优先级,分为OFF,FATAL,ERROR,WA R N,INFO,DEBUG,
ALL或者您定义的级别.Log4j建议只使用四个级别,优先级从高到低分别是ERROR,
WA R N,INFO,DEBUG.通过在这里定义的级别,您可以控制到应用程序中相应级别的日
志信息的开关.比如在这里定义了INFO级别,则应用程序中所有DEBUG级别的日志信息
将不被打印出来.appenderName就是指定日志信息输出到哪个地方.您可以同时指定多个
输出目的地.
②配置日志信息输出目的地Appender,其语法为
log4j.appender.appenderName = fully.qualified.name.of.appender.class
log4j.appender.appenderName.option1 = value1
log4j.appender.appenderName.option = valueN
其中,Log4j提供的appender有以下几种:
org.apache.log4j.ConsoleAppender(控制台),
org.apache.log4j.FileAppender(文件),
org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件),
org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件),
org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)
③配置日志信息的格式(布局),其语法为:
log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class
log4j.appender.appenderName.layout.option1 = value1
log4j.appender.appenderName.layout.option = valueN
其中,Log4j提供的layout有以下几种:
org.apache.log4j.HTMLLayout(以HTML表格形式布局),
org.apache.log4j.PatternLayout(可以灵活地指定布局模式),
org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),
org.apache.log4j.TTCCLayout(包含日志产生的时间,线程,类别等等信息)
④Log4J采用类似C语言中的printf函数的打印格式格式化日志信息,打印参数如下:
%m 输出代码中指定的消息
%p 输出优先级,即DEBUG,INFO,WA R N,ERROR,FATAL
%r 输出自应用启动到输出该log信息耗费的毫秒数
%c 输出所属的类目,通常就是所在类的全名
%t 输出产生该日志事件的线程名
%n 输出一个回车换行符,Windows平台为"\r\n",Unix平台为"\n"
%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,
比如:%d{yyy MMM dd HH:mm:ss,SSS},输出类似:2002年10月18日 22:10:28,921
%l 输出日志事件的发生位置,包括类目名,发生的线程,以及在代码中的行数.
对上面log4j.properties配置文件的一个应用;
作者: songjizheng 2006-12-29 17:51 回复此发言
--------------------------------------------------------------------------------
2 关于log4j的文章---粗略看了一遍,不错!
package log4j;
import org.apache.log4j.*;
// How to use log4j
public class TestLogging {
// Initialize a logging category. Here, we get THE ROOT CATEGORY
//static Category cat = Category.getRoot();
// Or, get a custom category
static Category cat = Category.getInstance(TestLogging.class.getName());
// From here on, log away! Methods are: cat.debug(your_message_string),
// cat.info(...), cat.warn(...), cat.error(...), cat.fatal(...)
public static void main(String args[]) {
// Try a few logging methods
PropertyConfigurator.configure ( "log4j.properties" ) ;
cat.debug("Start of main()");
cat.info("Just testing a log message with priority set to INFO");
cat.warn("Just testing a log message with priority set to WARN");
cat.error("Just testing a log message with priority set to ERROR");
cat.fatal("Just testing a log message with priority set to FATAL");
// Alternate but INCONVENIENT form
cat.log(Priority.DEBUG, "Calling init()");
new TestLogging().init();
}
public void init() {
java.util.Properties prop = System.getProperties();
java.util.Enumeration enum = prop.propertyNames();
cat.info("***System Environment As Seen By Java***");
cat.debug("***Format: PROPERTY = VALUE***");
while (enum.hasMoreElements()) {
String key = (String) enum.nextElement();
cat.info(key + " = " + System.getProperty(key));
}
}
}
xml格式的log4j配置文件概述
xml格式的log4j配置文件需要使用org.apache.log4j.html.DOMConfigurator.configure()方法来
读入.对xml文件的语法定义可以在log4j的发布包中找到:org/apache/log4j/xml/log4j.dtd.
Xml的一个配置文件:sample1.xml
说明:
①xml配置文件的头部包括两个部分:xml声明和dtd声明.头部的格式如下:
②log4j:configuration (root element)
xmlns:log4j [#FIXED attribute]: 定义log4j的名字空间,取定值"http://jakarta.apache.org/log4j/"
appender [* child] : 一个appender子元素定义一个日志输出目的地
logger [* child] : 一个logger子元素定义一个日志写出器
root [ child] : root子元素定义了root logger
源代码:
package exampleslog4j.xml;
import org.apache.log4j.xml.DOMConfigurator;
import org.apache.log4j.Category;
import java.net.*;
public class XMLSample {
static Category cat = Category.getInstance(XMLSample.class.getName());
public
static
void main(String argv[]) {
if(argv.length == 1)
init(argv[0]);
else
Usage("Wrong number of arguments.");
sample();
}
static
void Usage(String msg) {
System.err.println(msg);
System.err.println( "Usage: java " + XMLSample.class.getName() +
"configFile");
System.exit(1);
}
static
void init(String configFile) {
DOMConfigurator.configure(configFile);
}
static
void sample() {
int i = -1;
Category root = Category.getRoot();
cat.debug("Message " + ++i);
cat.warn ("Message " + ++i);
cat.error("Message " + ++i);
Exception e = new Exception("Just testing");
cat.debug("Message " + ++i, e);
}
}
执行后的效果:
2004-05-24 22:07:28,352 DEBUG [main] xml.XMLSample (XMLSample.java:55) - Message 0
2004-05-24 22:07:28,352 WARN [main] xml.XMLSample (XMLSample.java:56) - Message 1
作者: songjizheng 2006-12-29 17:51 回复此发言
--------------------------------------------------------------------------------
3 关于log4j的文章---粗略看了一遍,不错!
2004-05-24 22:07:28,362 ERROR [main] xml.XMLSample (XMLSample.java:57) - Message 2
2004-05-24 22:07:28,362 DEBUG [main] xml.XMLSample (XMLSample.java:59) - Message 3
java.lang.Exception: Just testing
at exampleslog4j.xml.XMLSample.sample(XMLSample.java:58)
at exampleslog4j.xml.XMLSample.main(XMLSample.java:36)
二,Log4J对数据库的操作:
其目的就是把日志信息写入数据库以方便开发人员和测试人员查询.
下面是写入数据库的配置文件:log4j.properties
log4j.appender.DATABASE=org.apache.log4j.jdbc.JDBCAppender
log4j.appender.DATABASE.URL=jdbc:oracle:thin:@192.168.0.1:1521:siemen
log4j.appender.DATABASE.driver= oracle.jdbc.driver.OracleDriver
log4j.appender.DATABASE.user=system
log4j.appender.DATABASE.password=css12345
log4j.appender.DATABASE.sql=INSERT INTO LOG4J (Message) VALUES ('[framework] %d
- %c -%-4r [%t] %-5p %c %x - %m%n')
log4j.appender.DATABASE.layout=org.apache.log4j.PatternLayout
log4j.appender.DATABASE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t]
%-5p %c %x - %m%n
log4j.appender.A1=org.apache.log4j.DailyRollingFileAppender
log4j.appender.A1.File=SampleMessages.log4j
log4j.appender.A1.DatePattern=yyyyMMdd-HH'.log4j'
log4j.appender.A1.layout=org.apache.log4j.xml.XMLLayout
对其应用的源文件:
package database.servlet;
import java.io.File;
import java.io.LineNumberReader;
import java.io.FileReader;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.util.Vector;
import java.sql.Driver;
import java.sql.DriverManager;
// import servlet packages
import javax.servlet.http.HttpServlet;
import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
// import log4j packages
import org.apache.log4j.Logger;
import org.apache.log4j.PropertyConfigurator;
public class SetupServlet extends HttpServlet{
public void init(ServletConfig config) throws ServletException{
super.init(config);
// first thing to do, is to set up the Driver that we might be using
// in case of JDBCAppender
try{
//Driver d =(Driver)(Class.forName("org.gjt.mm.mysql.Driver").newInstance());
Driver d = (Driver)(Class.forName("oracle.jdbc.driver.OracleDriver").newInstance());
DriverManager.registerDriver(d);
//加载JDBC驱动程序,当准备将日志记录到数据库的时候可以使用
}catch(Exception e){ System.err.println(e); }
// next load up the properties
//启动时从web.xml中获得配置文件的信息
String props = config.getInitParameter("props");
if(props == null || props.length() == 0 ||
!(new File(props)).isFile()){
System.err.println(
"ERROR: Cannot read the configuration file. " +
"Please check the path of the config init param in web.xml");
throw new ServletException();
}
}
public void destroy(){
super.destroy();
}
}
三,Log4J的封装:
配置文件:log4j.properties
log4j.rootLogger=DEBUG, A2, A1
log4j.appender.A2=org.apache.log4j.RollingFileAppender
log4j.appender.A2.File=C:\develop\log\error.log
log4j.appender.A2.Append=true
log4j.appender.R.MaxFileSize=10000KB
log4j.appender.A2.layout=org.apache.log4j.PatternLayout
作者: songjizheng 2006-12-29 17:51 回复此发言
--------------------------------------------------------------------------------
4 关于log4j的文章---粗略看了一遍,不错!
log4j.appender.A2.layout.ConversionPattern=[%-5p][%t] %d{yyyy-MM-dd
HH:mm:ss,SSS} message:%m%n
log4j.appender.A1=org.apache.log4j.ConsoleAppender
log4j.appender.A1.layout=org.apache.log4j.PatternLayout
#Pattern to output the caller's file name and line number.
#log4j.appender.stdout.layout.ConversionPattern=%5p [%t] (%F:%L) - %m%n
# Print the date in ISO 8601 format
log4j.appender.A1.layout.ConversionPattern=%d [%t] %-5p - %m%n
EncapsulationLog4J.java //Log4j的实现类
package com.cn.lx;
/**
*
Title:
*
Description:
*
Copyright: Copyright © 2004 lixiang
*
Company:http://www.css.com.cn/
* @author lixiang
* @version 1.0
*/
import org.apache.log4j.*;
import java.io.*;
import java.util.*;
/**
* @author Administrator
*
* To change the template for this generated type comment go to
* Window>Preferences>Java>Code Generation>Code and Comments
*/
public class EncapsulationLog4J
{
public static final String PROFILE = "log4j.properties";
/**
* Holds singleton instance
*/
private static EncapsulationLog4J impl;
static
{
impl = new EncapsulationLog4J();
}
private Logger log4j;
/**
* prevents instantiation
*/
private EncapsulationLog4J()
{
log4j = LogManager.getLogger(EncapsulationLog4J.class);
try
{
Properties pro = new Properties();
InputStream is = getClass().getResourceAsStream(PROFILE);
pro.load(is);
PropertyConfigurator.configure(pro);
}
catch(IOException e)
{
BasicConfigurator.configure();
e.printStackTrace();
}
}
public void log(String level,Object msg)
{
log(level,msg,null);
}
public void log(String level,Throwable e)
{
log(level,null,e);
}
public void log(String level,Object msg,java.lang.Throwable e)
{
if(log4j != null)
{
log4j.log((Priority)Level.toLevel(level),msg,e);
}
}
/**
* Singleton Pattern
*/
static public EncapsulationLog4J getInstance()
{
return impl;
}
}
Log.java //记录Log使用类
package com.cn.lx;
/**
*
Title:
*
Description:
*
Copyright: Copyright © 2004 lixiang
*
Company: http://www.css.com.cn/
* @author lixiang
* @version 1.0
*/
public class Log
{
private static EncapsulationLog4J log = EncapsulationLog4J.getInstance();
/**
*
*/
public Log()
{
//super();
}
public static void logError(String msg)
{
log.log("ERROR",msg);
}
public static void logError(Throwable e)
{
log.log("ERROR",null,e);
}
public static void logWarn(String msg)
{
log.log("WARN",msg);
}
public static void logWarn(Throwable e)
{
log.log("WARN",null,e);
}
public static void logInfo(String msg)
{
log.log("INFO",msg);
}
public static void logInfo(Throwable e)
{
log.log("INFO",null,e);
}
public static void logDebug(String msg)
{
log.log("DEBUG",msg);
}
public static void logDebug(Throwable e)
{
log.log("DEBUG",null,e);
}
}
TestLog.java //调用Log类
package com.cn.lx;
public class TestLog{
public static void main(String[] args) {
Log test = new Log();
test.logDebug("DEBUG");
test.logInfo("INFO");
test.logWarn("WARN");
test.logError("ERROR");
try
{
int i = Integer.parseInt("lixiang");
}catch(Exception e)
{
test.logDebug(e.toString());
test.logInfo(e.toString());
test.logWarn(e.toString());
test.logError(e.toString());
}
}
}
执行后的日志信息:
2004-05-26 21:16:16,474 [main] DEBUG - DEBUG
2004-05-26 21:16:16,484 [main] INFO - INFO
2004-05-26 21:16:16,484 [main] WARN - WARN
2004-05-26 21:16:16,484 [main] ERROR - ERROR
2004-05-26 21:16:16,484 [main] DEBUG - java.lang.NumberFormatException: For input string:
"lixiang"
2004-05-26 21:16:16,484 [main] INFO - java.lang.NumberFormatException: For input string:
"lixiang"
2004-05-26 21:16:16,484 [main] WARN - java.lang.NumberFormatException: For input string:
"lixiang"
2004-05-26 21:16:16,484 [main] ERROR - java.lang.NumberFormatException: For input string:
"lixiang"
注:使用此方法封装Log4j的操作,可以使记录日志变得更方便.唯一不足的是无法返回当
前类的相关信息.
最后说明:
关于对日志进行处理的技术有好多,如JDK 1.4 logging,Avalon LogKit,Jakarta 的Log4J
,Jakarta的Commons-Logging等.做的最好的是Commons-Logging.下面对其做一介绍:
The Jakarta Commons Logging (JCL) provides a Log interface that is
intended to be both light-weight and independent of numerous logging
toolkits. It provides the middleware/tooling developer with a simple logging
abstraction, that allows the user (application developer) to plug in a specific
logging implementation.
The Jakarta Commons Logging provides a Log interface with
thin-wrapper implementations for other logging tools, including
Log4J , Avalon LogKit , the Avalon Framework's logging
infrastructure, JDK 1.4, and an implementation of JDK 1.4 logging
APIs (JSR-47) for pre-1.4 systems. The interface maps closely to
Log4J and LogKit.
相关推荐
Log4j是一个广泛使用的Java日志记录框架,它允许开发者在应用程序中轻松地记录各种级别的日志信息,如DEBUG、INFO、WARN、ERROR等。在2021年底,一个重大的安全漏洞(CVE-2021-44228)被发现在Log4j2的早期版本中,...
Log4j是一款广泛使用的开源日志框架,由Apache软件基金会开发。本文将深入探讨Log4j的基本概念、配置与使用方法。 1. **什么是Log4j** Log4j是一个基于Java的日志记录工具,它提供了灵活的控制来记录日志信息,...
然后使用Logger.getLogger()方法获取日志记录器,而Log4j2需要import org.apache.logging.log4j.Level、org.apache.logging.log4j.LogManager和org.apache.logging.log4j.Logger,使用LogManager.getLogger()方法...
Log4j 使用总结 Log4j 是 Apache 的一个开放源代码项目,通过使用 Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI 组件、甚至是套接口服务器、NT 的事件记录器、UNIX Syslog 守护进程等;我们也可以...
Log4j和Log4j2是两种广泛使用的Java日志框架,它们提供了灵活的日志配置和高性能的日志处理能力。本文将详细介绍如何在SpringBoot项目中配置Log4j和Log4j2。 ### SpringBoot与Log4j Log4j是Apache的一个开源项目,...
总结,SLF4J和Log4j的组合使用让日志管理更加灵活,开发者可以通过SLF4J的简洁API进行日志记录,同时利用Log4j的强大功能,如自定义输出格式和多种输出目的地。通过适当的配置和测试,我们可以确保日志系统按照预期...
描述中的"NULL"意味着没有额外的具体信息,但我们通常可以从Log4j的使用上下文中了解到,它广泛用于调试、性能分析和系统监控,通过输出详细的运行时信息帮助开发者理解程序状态和追踪问题。 **标签解析** "源码...
针对Log4j 2 远程代码执行漏洞,需要用到的升级资源包,适用于maven资源库,包括log4j,log4j-core,log4j-api,log4j-1.2-api,log4j-jpa等全套2.15.0 maven资源库jar包。如果是maven本地仓库使用,需要将zip包解压...
Log4j2 结合 Slf4j 配置使用 Log4j2 是一个功能强大且广泛使用的日志记录工具,它提供了灵活的日志记录机制和高性能的日志记录能力。Slf4j 则是一个简单的日志记录门面,提供了统一的日志记录接口。今天,我们将...
Log4j、Log4j2和Fastjson的安全性问题在过去曾引起广泛关注,例如Log4j2的CVE-2021-44228(也被称为Log4Shell漏洞),这是一个远程代码执行漏洞,影响了许多使用Log4j2的系统。这个插件可能就是为了检测和利用这些...
9. **Layouts的广泛适用性**:Log4j2的Layouts不仅可以应用于使用`OutputStream`写入日志的Appender,还可以应用于所有类型的Appender。 10. **优化的并发支持**:Log4j2利用Java 5提供的并发特性,能够在较低级别...
### Log4j 使用实例详解 #### 一、Log4j简介 Log4j 是一个开源的日志记录框架,由 Apache 软件基金会提供。它允许开发者根据需求配置日志等级,并灵活选择日志信息的输出方式。Log4j 的核心组件包括 Logger、...
apache-log4j-1.2.15.jar, apache-log4j-extras-1.0.jar, apache-log4j-extras-1.1.jar, apache-log4j.jar, log4j-1.2-api-2.0.2-javadoc.jar, log4j-1.2-api-2.0.2-sources.jar, log4j-1.2-api-2.0.2.jar, log4j-...
### Log4j 使用详解 #### 一、Log4j简介 Log4j 是 Apache 的一个开源项目,通过使用 Log4j,开发者能够控制日志信息的输出等级及去向,从而更加灵活地处理日志信息。它具有强大的功能,简单的配置,并且能够支持...
分别有disruptor-3.3.4.jar(Log4j2异步日志的底层实现)、log4j-api-2.19.0.jar(log4j门面)、log4j-core-2.19.0.jar(log4j实现)、log4j-slf4j-impl-2.19.0.jar(SLF4J与Log4j绑定)、slf4j-api-1.7.30.jar(SLF...
此次提及的`log4j-api-2.12.4.jar`和`log4j-core-2.12.4.jar`是Log4j 2框架的两个关键组件,版本号为2.12.4,这个版本主要修复了之前版本中可能存在的安全漏洞。 **log4j-api-2.12.4.jar** 是Log4j 2框架的API模块...
例如,`org.apache.logging.log4j.core.appender.ConsoleAppender`用于将日志输出到控制台,而`org.apache.logging.log4j.core.layout.PatternLayout`则可以按照自定义的模式格式化日志信息。 Log4j2的亮点之一是其...
下面是一个简单的`log4j.properties`配置示例,用于将日志写入数据库: ``` log4j.rootLogger=DEBUG, DBAppender log4j.appender.DBAppender=org.apache.log4j.jdbc.JDBCAppender log4j.appender.DBAppender.URL=...
Log4j 是一个功能强大且广泛使用的日志记录工具,特别是在 SSM(Spring、Spring MVC、Mybatis)整合项目中,合理地配置 Log4j 对项目的日志记录和输出至关重要。本文将详细介绍 SSM 整合中的 Log4j 配置详情,帮助...
Log4j是Apache软件基金会开发的一个用于Java应用程序的日志记录工具,它提供了灵活的日志记录功能,有助于调试、性能分析和系统监控。"API"(Application Programming Interface)通常指的是开发者用来与库或框架...