`

log4j 重写JDBCAppender时使用spring管理的bean

阅读更多

   在使用log4j往数据库里写日志时 有以下两种方式可实现:

                   1. 在自己重写的MyJDBCAppender中 手动调用applicationContext.xml时 在手动获取datasource  (bean)

                  

ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");        
	 dataSource = (DataSource) context.getBean("dataSource");

                 

          

            2. 在自己重写的MyJDBCAppender中通过以下方式调用bean

         ServletContext  sc=(ServletContext)MyServletContextListener.local.get();
          ApplicationContext context = WebApplicationContextUtils.getWebApplicationContext(sc);
	     dataSource = (DataSource) context.getBean("dataSource");

     以上方式需要获取到servletContext。通过在web.xml添加一个监听器,在监听器中获取servletContext并存至本地:

public class MyServletContextListener implements ServletContextListener{
	
	public static ThreadLocal local=new ThreadLocal();

	private ServletContext context=null;


	public void contextDestroyed(ServletContextEvent event) {

		this.context=null;

	}

	//初始化

	public void contextInitialized(ServletContextEvent event) {

		this.context=event.getServletContext();
		local.set(context);//放到线程池

	}

}

 web.xml中配置

<listener>
 	<listener-class>com.xxxx.www.util.MyServletContextListener</listener-class>
 </listener>

 

在MyJDBCAppender 中调用

    ServletContext  sc=(ServletContext)MyServletContextListener.local.get();

 

ok,第二种方式顺利拿到spring中的各种bean.

分享到:
评论

相关推荐

    log4j日志驱动包

    log4j.appender.DATABASE=org.apache.log4j.jdbc.JDBCAppender log4j.appender.DATABASE.URL=jdbc:mysql://localhost:3306/test log4j.appender.DATABASE.driver=com.mysql.jdbc.Driver log4j.appender.DATABASE....

    log4jToJDBCAppender.zip

    本工程用于研究log4j日志输出目的地org.apache.log4j.jdbc.JDBCAppender的使用方法 本工程编码方式:UTF-8 本工程开发工具:MyEclipse 本工程需要执行的SQL语句: CREATE DATABASE `test`; CREATE TABLE `...

    Java进阶课程日志框架视频教程

    -日志课程大纲.xlsx ...--16-Log4j的JDBCAppender配置.mp4 --17-Log4j的自定义logger.mp4 --18-JCL入门介绍.mp4 --19-JCL原理介绍.mp4 -- ---讲义 -日志技术(上).pdf - --day02 -day02资料.zip -

    log4j jdbc 插件

    国外开源项目 用于控制log4j的 jdbc输出

    自己封装的JDBC连接通过properties文件读取配置文件

    自己封装的JDBC连接通过properties文件读取配置文件

Global site tag (gtag.js) - Google Analytics