幽昙 2011-05-18 23:47 采纳率: 0%
浏览 598
已采纳

Spring整合log4j 保存日志到数据库

我想用log4j把日志信息保存到数据库,但是我又想让log4j使用spring配置的数据库连接池,于是我重新写了一个appender类继承于JDBCAppender,然后在spring配置文件中给其注入DataSource对象,代码如下:
package com.cxl.appender;

import java.sql.Connection;
import java.sql.SQLException;

import javax.sql.DataSource;

import org.apache.log4j.jdbc.JDBCAppender;
public class MyJdbcAppender extends JDBCAppender {
private DataSource dataSource;
public DataSource getDataSource() {
return dataSource;
}
public void setDataSource(DataSource dataSource) {
this.dataSource = dataSource;
}
public MyJdbcAppender()
{
super();
}
@Override
protected Connection getConnection() {
try {
this.connection=dataSource.getConnection();
} catch (SQLException e) {
e.printStackTrace();
}
return super.connection;
}

Spring配置文件如下:


com.mysql.jdbc.Driver


jdbc:mysql://127.0.0.1:3306/scutcs


root


chen


3


10


50


60


100


30


60

<bean id="myAppender" class="com.cxl.appender.MyJdbcAppender">
    <property name="dataSource" ref="dataSource"/>
</bean>

问题是:
我启动tomcat的时候,不能把dataSource注入到MyJdbcAppender对象中,dataSouce总是为null报空指针异常.

  • 写回答

2条回答 默认 最新

  • iteye_667 2011-05-19 21:49
    关注

    好吧,我想起来了,一般情况下,log4j在spring启动之前就初始化好了的。所以datasource为null。
    LZ可以跟一下DOMConfigurer.configure方法,从这里开始解析appender的。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 哪位能做百度地图导航触点播报?
  • ¥15 请问GPT语言模型怎么训练?
  • ¥15 已知平面坐标系(非直角坐标系)内三个点的坐标,反求两坐标轴的夹角
  • ¥15 webots有问题,无响应
  • ¥15 使用VH6501干扰RTR位,CANoe上显示的错误帧不足32个就进入bus off快慢恢复,为什么?
  • ¥15 大智慧怎么编写一个选股程序
  • ¥100 python 调用 cgps 命令获取 实时位置信息
  • ¥15 两台交换机分别是trunk接口和access接口为何无法通信,通信过程是如何?
  • ¥15 C语言使用vscode编码错误
  • ¥15 用KSV5转成本时,如何不生成那笔中间凭证