博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Log4j 配置文件(log4j.properties)的所在路径问题(转)
阅读量:6671 次
发布时间:2019-06-25

本文共 1428 字,大约阅读时间需要 4 分钟。

转自:http://hi.baidu.com/oritenson/blog/item/968992523f6793998d543022.html

一般我们直接将log4j.properties放置在src目录下,这样系统自动会找到的,其实就是放在WEB-INF/classes文件下。这个路径在classpath下,所以直接就能找到。我们写Logger的时候如下:

public class HelloLog4j {


  
    public static Logger logger = Logger.getLogger(HelloLog4j.class);

    public static void main(String[] args) {       
        logger.debug("This is debug message.");
        logger.info("This is info message.");
        logger.error("This is error message.");
        xxx();
    }
    
    public static void xxx(){

        logger.debug("main method has invoked xxx method.");
    }
}

如果现在我们想把log4j.properties文件放置在其它目录下,例如:WEB-INF下和web.xml放在一起。这时候就需要我们手动指定log4j配置文件的路径,否则系统是找不到的。

一、首先我们在web.xml中配置好log4j.properties路径:

        <context-param>
            <param-name>log4jConfigLocation</param-name>
            <param-value>/WEB-INF/log4j.properties</param-value>
        </context-param>

二、然后写个servlet,部分代码如下:

public void init() {


    String prefix = getServletContext().getRealPath("/");
    String file = getInitParameter("log4jConfigLocation");
    if (file != null) {

      PropertyConfigurator.configure(prefix + file);     
    }
}

三、在web.xml中配置servlet,并将log4jConfigLocation加入到Servlet中,让其Server启动即运行:

<servlet>
   <servlet-name>your servlet</servlet-name>
   <servlet-class>your servelt class</servlet-class>
   <init-param>
      <param-name>log4jConfigLocation</param-name>
      <param-value>/WEB-INF/log4j.properties</param-value>
    </init-param>
   <load-on-startup>1</load-on-startup>
</servlet>

转载于:https://www.cnblogs.com/zhihaowang/archive/2011/08/24/10128435.html

你可能感兴趣的文章
解析MYSQL BINLOG 二进制格式(2)--FORMAT_DESCRIPTION_EVENT
查看>>
Oracle 12c DBCA浅析(r12笔记第48天)
查看>>
MYSQL INNODB innodb_thread_concurrency相关参数理解
查看>>
SQL优化常用方法16
查看>>
Oracle并行操作——并行DML操作
查看>>
[转]Django Practice - Django 权限控制
查看>>
Raid5数据恢复原理_两块盘离线数据恢复方法
查看>>
缓存之EHCache(转)
查看>>
FirewallD 详解
查看>>
码农和程序员之间的5个关键差异(转)
查看>>
RocksDB TransactionDB事务实现分析
查看>>
Web---自己写的一个简单云相册~
查看>>
SQLServer RESOURCE_SEMAPHORE 等待状态
查看>>
VBA读取word中的内容到Excel中
查看>>
Tomcat 7最大并发连接数的正确修改方法(转)
查看>>
开源分布式任务调度平台Cuckoo-Schedule
查看>>
20170224测试数据库块在文件系统缓存多少
查看>>
Statement和PreparedStatement的区别; 什么是SQL注入,怎么防止SQL注入? (转)
查看>>
微信小程序把玩(十一)icon组件
查看>>
当计算停留着网格内 Mellanox用智能网络助跑AI
查看>>