Log4j不写日志文件

时间:2014-02-17 13:50:26

标签: java log4j

我尝试使用ServletContext首次使用我的Java Web Aaplication进行日志记录。我没有收到任何日志文件。有人可以告诉我我做的不对吗?

我的ServletContextListener:

@Override
    public void contextInitialized(ServletContextEvent sce) {

        ServletContext context = sce.getServletContext();
        String prefix = context.getRealPath("/");
        String file = "WEB-INF" + System.getProperty("file.separator") + "classes" + System.getProperty("file.separator") + "log4j.properties";

        if (file != null) {
            PropertyConfigurator.configure(prefix + file);
            System.out.println("Log4J Logging started for application: " + prefix + file);
        } else {
            System.out.println("Log4J Is not configured for application Application: " + prefix + file);
        }
    }

我的Web.xml:

<listener>
        <listener-class>com.kollega.listener.KollegaContextListener</listener-class>
    </listener>

Log4j.properties文件:

log4j.logger.kollegalogger=DEBUG, C, fileappender
log4j.appender.fileappender=org.apache.log4j.RollingFileAppender
log4j.appender.fileappender.File=/WEB-INF/logs/kollega.log
log4j.appender.fileappender.MaxFileSize=500KB

My Test Servlet:

private final Logger log = Logger.getLogger("kollegalogger");
log.debug(">>> Connectition TO database Successful for Login");
        Logger.getLogger(LoginServlet.class.getName()).log(Level.FATAL, ">>>>Connectition TO database Successful for Login");

仅获取DEBUG的输出,但WEB-INF / logs / kollega.log中没有日志文件。我错过了什么?

修改 * 我从文件路径中删除了$ {appRootPath},并且在C:/WEB-INF/logs/kollega.log中创建了日志。我需要在我的WEB-INF目录 *

2 个答案:

答案 0 :(得分:1)

试一试。 Web应用程序中的路径相对于/WEB-INF而非WEB-INF

工作
String file = System.getProperty("file.separator")+"WEB-INF" + System.getProperty("file.separator") + "classes" + System.getProperty("file.separator") + "log4j.properties";

答案 1 :(得分:0)

将属性文件放在类文件所在的类路径中或WEB-INF/classes中,然后您可以按如下方式轻松加载:

PropertyConfigurator.configure("log4j.properties");**