webAppRootKey

 在tomcat下面同时启动多个项目的时候出现了一个错误,刚开始没找见,后来在网上查看才知道是自己对log4j配置不清楚造成的。

使用spring中的Log4jConfigListener有如如下好处: 
   1. 动态的改变记录级别和策略,不需要重启Web应用,如《Effective Enterprise Java》所说。 
   2. 把log文件定在 /WEB-INF/logs/ 而不需要写绝对路径。 
因为 系统把web目录的路径压入一个叫webapp.root的系统变量。这样写log文件路径时不用写绝对路径了. 
log4j.appender.logfile.File=${webapp.root}/WEB-INF/logs/myfuse.log 
   3. 可以把log4j.properties和其他properties一起放在/WEB-INF/ ,而不是Class-Path。 


1、 web.xml配置 

webAppRootKey
webapp.root

"webapp.root"这个字符串可以随便写任何字符串。如果不配置默认值是"webapp.root"。

例如 我现在第一个项目设置的是webapp.root 运行的时候就会出现这个

信息: Initializing log4j from [F:\Workspaces\MyEclipseProfessional\.metadata\.me_tcat7\webapps\weshop\WEB-INF\classes\log4j.properties]

这个。

      由于我的两个项目的context-param设置的param-value都是webapp.root那么当启动的时候就会报错,因为你的webapp.root的这个key的value值已经制定了第一个项目,不能再指向第二个项目,所以就会报错。把第二个项目的param-value改掉,项目启动无错误。

最后再说下这个


     webAppRootKey
     tsts.root
 
然后再配置这样一个监听器:

      
         org.springframework.web.util.WebAppRootListener
     

这个监听器就会在web上下文初始化的时候,调用webUtil的对应方法,首先获取到param-name对应的param-value ,然后,根据传递进去的ServletContext对象得到web的物理路径:String root = servletContext.getRealPath("/");

接着把这个param-value作为key,root作为value放到system中System.setProperty(key, root);然后再web中可以用 System.get.....就可以得到web的跟目录的物理路径了。

终于明白了


 
  


你可能感兴趣的:(java)