当你的工程放了struts2.0.11/lib下的所有jars但没放log4j.jar会如何?

     我们总是需要开始,总是需要尝试,总是不断地去发现,去改进!
     我只是想让struts2跑起来,很低的要求,我大约用了4个晚上的时间,菜,好菜!好多波折啊,好多辛酸!
     这是一篇写给超级才鸟的文章,因此坚决不会发到论坛里去!
     其实发到论坛里的动机很单纯,一个是容易被更多人看到,一个是升级为能投票的会员,行使人间的正义权利!但此篇仅仅发表在blog里,如果某天有人遇到的这样的情况(可能性很小的),可以翻阅此文!
        首先,下载struts2,地址为:http://struts.apache.org/,这里看到的是2.0.11GA,就用这个版本!
         随便在硬盘上找个地方建立ROOT /WEB-INF/,classes和lib目录,当然可以在ROOT下建立个index.htm什么的文件,欢迎一下!好,开始动手了,把 struts2.0.11/lib下面的jar包都拷贝到ROOT/WEB-INF/lib目录里,都拷贝进去!这还不够,再找点spring的文件,把 spring/的常用的那几个jar也拷贝到lib目录去,包括:spring.jar,spring-aop.jar,spring- beans.jar,spring-context.jar,spring-core.jar,spring-mock.jar,spring- support.jar,spring-web.jar;然后在ROOT/WEB-INF/ 下建立web.xml文件,内容如下:
   1.  <? xml version="1.0" encoding="UTF-8" ?>   
   2. 
< web-app  id ="WebApp_9"  version ="2.4"  xmlns ="http://java.sun.com/xml/ns/j2ee"  xmlns:xsi ="http://www.w3.org/2001/XMLSchema-instance"  xsi:schemaLocation ="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd" >   
   3.   
   4.     
< display-name > Struts Blank </ display-name >   
   5.     
< context-param >   
   6.         
< param-name > contextConfigLocation </ param-name >   
   7.         
< param-value >   
   8.             /WEB-INF/classes/applicationContext-*.xml  
   9.         
</ param-value >   
  10.     
</ context-param >   
  11.     
< listener >   
  12.         
< listener-class >   
  13.             org.springframework.web.context.ContextLoaderListener  
  14.         
</ listener-class >   
  15.     
</ listener >   
  16.     
< filter >   
  17.         
< filter-name > struts2 </ filter-name >   
  18.         
< filter-class > org.apache.struts2.dispatcher.FilterDispatcher </ filter-class >   
  19.     
</ filter >   
  20.   
  21.     
< filter-mapping >   
  22.         
< filter-name > struts2 </ filter-name >   
  23.         
< url-pattern > /* </ url-pattern >   
  24.     
</ filter-mapping >   
  25.   
  26.     
< welcome-file-list >   
  27.         
< welcome-file > index.html </ welcome-file >   
  28.     
</ welcome-file-list >   
  29.   
  30. 
</ web-app >   
然后到ROOT/WEB-INF/classes/下建立struts.xml文件,内容如下:
   1.  <? xml version="1.0" encoding="UTF-8"  ?>   
   2. 
<! DOCTYPE struts PUBLIC  
   3.     "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"  
   4.     "http://struts.apache.org/dtds/struts-2.0.dtd"
>   
   5.   
   6. 
< struts >   
   7.   
   8.     
< constant  name ="struts.enable.DynamicMethodInvocation"  value ="false"   />   
   9.     
< constant  name ="struts.devMode"  value ="false"   />   
  10.   
  11.   
  12.     
<!--  Add packages here  -->   
  13.   
  14. 
</ struts >   
 
ok,工作做完了,接下来把此目录部署到tomcat里成一个站点,补充一下:tomcat用5.5.25,jdk用5.0.
好了,你可以启动你的tomcat了,启动tomcat,看tomcat/logs/catalina.2007-12-03.log,当然是你运行时的日期,呵呵!
发现了什么,我想你一定会发现以下的错误:
Actual exception
Could not load class org.apache.struts2.jsf.FacesSetupInterceptor. Perhaps it exists but certain dependencies are not available? - interceptor - jar:file:/D:/website/MedicalChina/ROOT/WEB-INF/lib/struts2-jsf-plugin-2.0.11.jar!/struts-plugin.xml:36:97
..............................................
Caused by: java.lang.NoClassDefFoundError: javax / faces / lifecycle / Lifecycle
(这句很重要,重要个屁,这句一点用也没有),貌似缺少jar包,但不知道缺少哪一个,呵呵!
在下经过详细的考证,发现缺少的是log4j.jar,呵呵,你再把log4j.jar放到lib里,重起tomcat就一切正常了!
很简单吧,是简单,但你能从包错信息“Caused by: java.lang.NoClassDefFoundError: javax/faces/lifecycle/Lifecycle”想到缺少的是log4j.jar这个包吗?我花了n个小时才明白了这个事情!

      所以,我把它记录下来,供以后查阅,更供大家参考!

       赶兴趣的,可以去查源码,看为啥如此,呵呵! 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值