struts2 2.1.6报错 严重: Exception starting filter struts2

struts2  2.1.6报错  严重: Exception starting filter struts2 
用的是struts2  2.1.6 
web.xml中的struts2过滤器为: 
Java代码   收藏代码
  1. <filter>  
  2.         <filter-name>struts2</filter-name>  
  3.         <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>  
  4.     </filter>  
  5.   
  6.     <filter-mapping>  
  7.         <filter-name>struts2</filter-name>  
  8.         <url-pattern>/*</url-pattern>  
  9.     </filter-mapping>  

这个不同于struts2的2.0版本的过滤器: 
Java代码   收藏代码
  1. <filter>  
  2.         <filter-name>struts2</filter-name>  
  3.         <filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class>  
  4.     </filter>  
  5.     <filter-mapping>  
  6.         <filter-name>struts2</filter-name>  
  7.         <url-pattern>/*</url-pattern>  
  8.     </filter-mapping>  


2.1.6在部署到tomcat中去,启动的时候报错: 
java.lang.NullPointerException 
at com.opensymphony.xwork2.util.FileManager$FileRevision.needsReloading(FileManager.java:209) 
at com.opensymphony.xwork2.util.FileManager.fileNeedsReloading(FileManager.java:60) 
at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.needsReload(XmlConfigurationProvider.java:325)
at org.apache.struts2.config.StrutsXmlConfigurationProvider.needsReload(StrutsXmlConfigurationProvider.java:168)
at com.opensymphony.xwork2.config.ConfigurationManager.conditionalReload(ConfigurationManager.java:220) 
at com.opensymphony.xwork2.config.ConfigurationManager.getConfiguration(ConfigurationManager.java:61) 
at org.apache.struts2.dispatcher.Dispatcher.getContainer(Dispatcher.java:774) 
at org.apache.struts2.dispatcher.FilterDispatcher.init(FilterDispatcher.java:191) 
at org.apache.catalina.core.ApplicationFilterConfig.getFilter(ApplicationFilterConfig.java:275) 
at org.apache.catalina.core.ApplicationFilterConfig.setFilterDef(ApplicationFilterConfig.java:397) 
at org.apache.catalina.core.ApplicationFilterConfig. <init>(ApplicationFilterConfig.java:108) 
at org.apache.catalina.core.StandardContext.filterStart(StandardContext.java:3709) 
at org.apache.catalina.core.StandardContext.start(StandardContext.java:4356) 
at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:791) 
at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:771) 
at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:525) 
at org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java:924) 
at org.apache.catalina.startup.HostConfig.deployDirectories(HostConfig.java:887) 
at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:492) 
at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1147) 
at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:311) 
at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:117) 
at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1053) 
at org.apache.catalina.core.StandardHost.start(StandardHost.java:719) 
at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045) 
at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:443) 
at org.apache.catalina.core.StandardService.start(StandardService.java:516) 
at org.apache.catalina.core.StandardServer.start(StandardServer.java:710) 
at org.apache.catalina.startup.Catalina.start(Catalina.java:578) 
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 
at java.lang.reflect.Method.invoke(Method.java:597) 
at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:288) 
at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:413) 
2009-2-19 9:47:43 org.apache.catalina.core.StandardContext start 
严重: Error filterStart 
-------------------------------------------------- 
你可以试一下修改在struts.xml里 , 
<constant name="struts.devMode" value="true" /> 
把上面这句话改为 
<constant name="struts.devMode" value="false" />    
如果能启动成功说明我们问题一样。 

现在你把value的值改为true,然后再去改安装版tomcat的路径, 

把tomcat的路径改在C盘得根目录下,然后tomcat的路径中不能有空格,你再启动试试,应该就可以了。 


其实这个是Struts2.1.6的一个BUG,Tomcat的路径不能有空格。 

最后我又测试了一下免安装版的tomcat,就不用改在c盘根目录下。测试也通过。Tomcat的路径不能有空格。  

注意:2.1.6版本可以直接在url中,输入例如: http://localhost:8088/Struts2_Test/user/user!add?user.name=a&user.age=8  
add方法后面不用加.action,而2.0版本必须加.action,否则访问不到。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值