在 log4j.xml 配置中使用 JVM 变量不起作用...
System.setProperty("log_dir", logDirPath);
<param name="file" value="${log_dir}\toto.log" />
如果我在调试运行时重新加载 Web 服务器,它就会起作用...
** 更新
package com.webapp.startup;
import java.io.PrintStream;
import javax.servlet.ServletContext;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
import org.apache.log4j.Level;
import org.apache.log4j.Logger;
import org.apache.log4j.PropertyConfigurator;
import com.webapp.objects.impl.LoggingOutputStream;
public class Log4jStartup implements ServletContextListener{
@Override
public void contextDestroyed(ServletContextEvent arg0) {
}
@Override
public void contextInitialized(ServletContextEvent event) {
try {
ServletContext context = event.getServletContext();
System.setProperty("log_dir", "C:/path");
System.setErr(new PrintStream(new LoggingOutputStream(Logger.getRootLogger(), Level.ERROR), true));
System.setOut(new PrintStream(new LoggingOutputStream(Logger.getRootLogger(), Level.INFO), true));
String path = context.getRealPath("/WEB-INF/classes/log4j.xml");
PropertyConfigurator.configure(path);
} catch (Exception e) {
e.printStackTrace();
}
}
}
在 setErr 和 setOut 之前初始化属性... 感谢大家!
最佳答案
您可能在 log4j
系统初始化后填充该属性。
为了之前完成它,您可以在启动服务器时从命令行提供它,或者使用初始化 servlet,如 this example 中所示。 。滚动到 Tomcat 下的默认初始化,并记住您只需要指定属性而不是 log4j 配置文件。
关于java - Log4J - J2EE - 动态变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23625976/