[url]http://kin111.blog.51cto.com/738881/158612[/url]
Log4j中的LogFactor5是Log4j的Appender的一个实现。LogFactor5可以图形的形式表示log信息。并且可以对表示的Log信息进行筛选。适合于使用Log4j时查看log的调试。
本文简单介绍LogFactor5的使用方法。
本文示例使用的Log4j版本为:apache-log4j-1.2.15
1。运行LogFactor5的简单方法:
在有log4j-1.2.15.jar文件的目录下从命令行执行:
java -classpath .;log4j-1.2.15.jar org.apache.log4j.lf5.StartLogFactor5即可
表示出一个GUI图形界面。如下图
[img]http://kin111.blog.51cto.com/attachment/200905/200905161242543082026.jpg[/img]
从File菜单选OPEN菜单,从文件选择对话框中选择\apache-log4j-1.2.15\examples\lf5\OpeningLogFiles\sample.log文件后,GUI图形界面内容变化,即可表示出log内容。如下图
[img]http://kin111.blog.51cto.com/attachment/200905/200905161242543107996.jpg[/img]
2。生成可以被LogFactor5GUI图形界面表示的Log方法。
这需要使用Class LF5Appender。这个Class位于org.apache.log4j.lf5包中。
有很多方法可以调用到LF5Appender。
最简单的一种方法如下:
使用DefaultLF5Configurator.configure();
示例代码:
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package examples.lf5.InitUsingDefaultConfigurator;
import org.apache.log4j.Logger;
import org.apache.log4j.NDC;
import org.apache.log4j.lf5.DefaultLF5Configurator;
import java.io.IOException;
/**
* This class is a simple example of how to configure the LogFactor5
* logging window using the DefaultLF5Configurator.
*
* The DefaultLF5Configurator uses a default configuration file stored
* in the log4j.jar in order to provide a default configuration for
* the LF5Appender.
*
* @author Brent Sprecher
*/
// Contributed by ThoughtWorks Inc.
public class InitUsingDefaultConfigurator {
//--------------------------------------------------------------------------
// Constants:
//--------------------------------------------------------------------------
//--------------------------------------------------------------------------
// Protected Variables:
//--------------------------------------------------------------------------
//--------------------------------------------------------------------------
// Private Variables:
//--------------------------------------------------------------------------
private static Logger logger =
Logger.getLogger(InitUsingDefaultConfigurator.class);
//--------------------------------------------------------------------------
// Constructors:
//--------------------------------------------------------------------------
//--------------------------------------------------------------------------
// Public Methods:
//--------------------------------------------------------------------------
public static void main(String[] args) throws IOException {
// Configure the LF5Appender using the DefaultLF5Configurator. This
// will add the LF5Appender to the root of the Category tree.
DefaultLF5Configurator.configure();
// Add an NDC to demonstrate how NDC information is output.
NDC.push("#23856");
// Log some information.
for (int i = 0; i < 10; i++) {
logger.debug("Hello, my name is Homer Simpson.");
logger.info("Mmmmmm .... Chocolate.");
logger.warn("Mmm...forbidden donut.");
}
// Clean up NDC
NDC.pop();
NDC.remove();
NDC.push("Another NDC");
// Log some information.
logger.fatal("Hello, my name is Bart Simpson.");
logger.error("Hi diddly ho good neighbour.");
// Clean up NDC
NDC.pop();
NDC.remove();
// Call methods on both classes.
InitUsingDefaultConfigurator.foo();
InnerInitUsingDefaultConfigurator.foo();
logger.info("Exiting InitUsingDefaultConfigurator.");
}
public static void foo() {
logger.debug("Entered foo in InitUsingDefaultConfigurator class");
NDC.push("#123456");
logger.debug("Hello, my name is Marge Simpson.");
logger.info("D'oh!! A deer! A female deer.");
// Clean up NDC
NDC.pop();
NDC.remove();
}
//--------------------------------------------------------------------------
// Protected Methods:
//--------------------------------------------------------------------------
//--------------------------------------------------------------------------
// Private Methods:
//--------------------------------------------------------------------------
//--------------------------------------------------------------------------
// Nested Top-Level Classes or Interfaces:
//--------------------------------------------------------------------------
public static class InnerInitUsingDefaultConfigurator {
static Logger logger =
Logger.getLogger(InnerInitUsingDefaultConfigurator.class.getName());
static void foo() throws IOException {
// Configure the LF5Appender again. You can call
// DefaultLF5Configurator.configure() as often as you want
// without unexpected behavior.
DefaultLF5Configurator.configure();
logger.info("Entered foo in InnerInitUsingDefaultConfigurator class.");
}
}
}
编译:
javac -classpath .;log4j-1.2.15.jar InitUsingDefaultConfigurator.java
得到InitUsingDefaultConfigurator$InnerInitUsingDefaultConfigurator.class
和InitUsingDefaultConfigurator.class
执行:
java -classpath .;log4j-1.2.15.jar examples.lf5.InitUsingDefaultConfigurator.InitUsingDefaultConfigurator
会启动LogFactor5的图形界面,并把输出Log的内容表示到界面中。如下图:
[img]http://kin111.blog.51cto.com/attachment/200905/200905161242543142205.jpg[/img]
3,LogFactor5的Log的格式
LogFactor5的Log的格式是固定的。如下示例
中括号的规定的标记。
[slf5s.start]26 Jul 2001 15:54:44,673[slf5s.DATE]
DEBUG[slf5s.PRIORITY]
[slf5s.NDC]
main[slf5s.THREAD]
examples.InitUsingMultipleAppenders.InitUsingMultipleAppenders[slf5s.CATEGORY]
examples.InitUsingMultipleAppenders.InitUsingMultipleAppenders.main(InitUsingMultipleAppenders.java:102)[slf5s.LOCATION]
Hello, my name is Homer Simpson.[slf5s.MESSAGE]
4,LogFactor5的package简介
org.apache.log4j.lf5 主要是appender,configurator,level,封装的log记录类,和启动类等等.
org.apache.log4j.lf5.util 主要是LogFactor5的实用类,读资源,处理流,swing的一些共通处理
org.apache.log4j.lf5.viewer 主要是gui的主窗口,各个dialog,表示log用的table,tablemodel等类
org.apache.log4j.lf5.viewer.categoryexplorer 主要是主窗口左边的category流览tree表示swing组件的支持的类
org.apache.log4j.lf5.viewer.configure 主要是处理最近打开文件历史,配置保存读取类