[首页]
[文章]
[教程]
首页
Web开发
Windows开发
编程语言
数据库技术
移动平台
系统服务
微信
设计
布布扣
其他
数据分析
首页
>
其他
> 详细
将log4j重定向到指定函数
时间:
2015-03-02 19:25:00
阅读:
500
评论:
0
收藏:
0
[点我收藏+]
测试程序源代码
[java]
view plain
copy
import
org.apache.log4j.Logger;
/**
* 使Log4j的log输出重定向到指定函数
* Last Update Date: 2014-01-23
* 依赖库
* [1]log4j-1.2.9.jar
* [2]JDK 1.6.x
* @author lijun
*
*/
public
class
TestMain{
static
Logger log = Logger.getLogger(TestMain.
class
.getName());
public
static
void
main(String[] args)
{
try
{
TestMain tm =
new
TestMain();
/*
打印所有的Appender实例
Enumeration enumd=log.getRootLogger().getAllAppenders();
while(enumd.hasMoreElements()){
Appender app=(Appender)enumd.nextElement();
System.out.println(app.getName());
System.out.println("in appender");
}
*/
/*
取Class的Method的方法
Class ptypes[] = new Class[1];
ptypes[0] = Class.forName("java.lang.String");
Method m = TestMain.class.getMethod("DebugMsg",ptypes);
*/
{
CallbackAppender ca = (CallbackAppender)Logger.
getRootLogger().getAppender(
"ca"
);
if
(ca!=
null
)
ca.SetCallback(tm.getClass().getMethod(
"DebugMsg"
,
new
Class[] {String.
class
}));
}
log.debug(
"from my appender!"
);
}
catch
(Exception ex)
{
ex.printStackTrace();
}
}
public
static
void
DebugMsg(String msg) {
System.out.println(
"现在log输出被指定到这里了 => "
+msg);
}
}
Appender源代码
[java]
view plain
copy
import
java.lang.reflect.Method;
import
org.apache.log4j.AppenderSkeleton;
import
org.apache.log4j.spi.LoggingEvent;
/**
*
* 这个Appender的作用,是使log输出重定向到某个函数里去
* @author lijun
*
*/
public
class
CallbackAppender
extends
AppenderSkeleton {
Method m_ian;
@Override
protected
void
append(LoggingEvent event) {
try
{
String msg =
this
.getLayout().format(event);
//调用方法重定向log输出.begin
if
( m_ian!=
null
)
{
Object[] args = {msg};
m_ian.invoke(
null
, args);
}
//调用方法重定向log输出.end
}
catch
(Exception ie) {
ie.printStackTrace();
}
}
@Override
public
void
close() {
if
(closed)
return
;
//Close动作
//Close标记
closed =
true
;
}
@Override
public
boolean
requiresLayout() {
return
true
;
}
public
void
SetCallback(Method ian)
{
m_ian = ian;
}
}
log4j.xml的配置清单
[html]
view plain
copy
<?
xml
version
=
"1.0"
encoding
=
"UTF-8"
?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd"
>
<
log4j:configuration
xmlns:log4j
=
‘http://jakarta.apache.org/log4j/‘
>
<
appender
name
=
"myConsole"
class
=
"org.apache.log4j.ConsoleAppender"
>
<
layout
class
=
"org.apache.log4j.PatternLayout"
>
<
param
name
=
"ConversionPattern"
value
=
"[%d{dd HH:mm:ss,SSS\} %-5p] [%t] %c{2\} - %m%n"
/>
</
layout
>
<!--过滤器设置输出的级别-->
<
filter
class
=
"org.apache.log4j.varia.LevelRangeFilter"
>
<
param
name
=
"levelMin"
value
=
"debug"
/>
<
param
name
=
"levelMax"
value
=
"warn"
/>
<
param
name
=
"AcceptOnMatch"
value
=
"true"
/>
</
filter
>
</
appender
>
<!-- 指定logger的设置,additivity指示是否遵循缺省的继承机制-->
<
appender
name
=
"ca"
class
=
"CallbackAppender"
>
<
layout
class
=
"org.apache.log4j.PatternLayout"
>
<
param
name
=
"ConversionPattern"
value
=
"[%d{dd HH:mm:ss,SSS\} %-5p] [%t] %c{2\} - %m%n"
/>
</
layout
>
</
appender
>
<!-- 根logger的设置-->
<
root
>
<
priority
value
=
"debug"
/>
<!-- <appender-ref ref="myConsole"/> -->
<
appender-ref
ref
=
"ca"
/>
</
root
>
</
log4j:configuration
>
将log4j重定向到指定函数
原文:http://my.oschina.net/u/1398304/blog/381398
踩
(
0
)
赞
(
0
)
举报
评论
一句话评论(
0
)
登录后才能评论!
分享档案
更多>
2021年09月23日 (328)
2021年09月24日 (313)
2021年09月17日 (191)
2021年09月15日 (369)
2021年09月16日 (411)
2021年09月13日 (439)
2021年09月11日 (398)
2021年09月12日 (393)
2021年09月10日 (160)
2021年09月08日 (222)
最新文章
更多>
2021/09/28 scripts
2022-05-27
vue自定义全局指令v-emoji限制input输入表情和特殊字符
2022-05-27
9.26学习总结
2022-05-27
vim操作
2022-05-27
深入理解计算机基础 第三章
2022-05-27
C++ string 作为形参与引用传递(转)
2022-05-27
python 加解密
2022-05-27
JavaScript-对象数组里根据id获取name,对象可能有children属性
2022-05-27
SQL语句——保持现有内容在后面增加内容
2022-05-27
virsh命令文档
2022-05-27
教程昨日排行
更多>
1.
list.reverse()
2.
Django Admin 管理工具
3.
AppML 案例模型
4.
HTML 标签列表(功能排序)
5.
HTML 颜色名
6.
HTML 语言代码
7.
jQuery 事件
8.
jEasyUI 创建分割按钮
9.
jEasyUI 创建复杂布局
10.
jEasyUI 创建简单窗口
友情链接
汇智网
PHP教程
插件网
关于我们
-
联系我们
-
留言反馈
- 联系我们:wmxa8@hotmail.com
© 2014
bubuko.com
版权所有
打开技术之扣,分享程序人生!