Spring提供了一个Log4jConfigListener,可以在web.xml中配置来指定位置加载log4j配置文件和log日志文件的路径。
原理即为这个listener在启动时将web目录的路径通过System.setProperty("webapp.root","")方法,为当前JVM SET了一个名为webapp.root的系统变量,这样可以通过在lo4j.properties中l设置相对文件路径,如:g4j.appender.logfile.File=${webapp.root}/logs/mylog.log 。
在web.xml 添加
<context-param>
<param-name>webAppRootKey</param-name>
<param-value>webapp.root</param-value>
</context-param>
<context-param>
<param-name>log4jConfigLocation</param-name>
<param-value>/WEB-INF/log4j.properties</param-value>
</context-param>
<context-param>
<param-name>log4jRefreshInterval</param-name>
<param-value>60000</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
</listener>
webAppRootKey,即为放入当前JVM的环境变量名。
log4jConfigLocation,log4j.properties的路径,可以放在/WEB-INF/下。
log4jRefreshInterval, 开一条watchdog线程每60秒扫描一下配置文件的变化; 可以不配置这个参数。
listener需要放在spring的Listener之前。 青年人网站收集整理!
责任编辑:小草