严重: Exception starting filter struts2
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.ng.InitOperations.initStaticContentLoader(InitOperations.java:77)
at org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter.init(StrutsPrepareAndExecuteFilter.java:49)
at org.apache.catalina.core.ApplicationFilterConfig.getFilter(ApplicationFilterConfig.java:223)
at org.apache.catalina.core.ApplicationFilterConfig.setFilterDef(ApplicationFilterConfig.java:304)
at org.apache.catalina.core.ApplicationFilterConfig.<init>(ApplicationFilterConfig.java:77)
at org.apache.catalina.core.StandardContext.filterStart(StandardContext.java:3634)
at org.apache.catalina.core.StandardContext.start(StandardContext.java:4217)
at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:759)
at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:739)
at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:524)
at org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java:904)
at org.apache.catalina.startup.HostConfig.deployDirectories(HostConfig.java:867)
at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:474)
at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1122)
at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:310)
at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:119)
at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1021)
at org.apache.catalina.core.StandardHost.start(StandardHost.java:718)
at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1013)
at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:442)
at org.apache.catalina.core.StandardService.start(StandardService.java:450)
at org.apache.catalina.core.StandardServer.start(StandardServer.java:709)
at org.apache.catalina.startup.Catalina.start(Catalina.java:551)
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:294)
at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:432)
2010-1-10 10:20:53 org.apache.catalina.core.StandardContext start
严重: Error filterStart
2010-1-10 10:20:53 org.apache.catalina.core.StandardContext start
严重: Context [/Struts2_1900_OGNL] startup failed due to previous errors
web.xml文件:    <filter>
        <filter-name>struts2</filter-name>
        <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
    </filter>    <filter-mapping>
        <filter-name>struts2</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>试过很多解决方法都不行,麻烦大侠们帮忙解决下。

解决方案 »

  1.   

    org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter
    那个filter好像不是这个哦.
    还有那个配置文件 设置 没.
      

  2.   

    其实这是我看视频教程上的一个小例子,代码原封不动地引入进来的,编译环境,开发环境都完全一样,可是一启动tomcat就报错,不知什么原因。
      

  3.   

    <filter>
    <filter-name>struts2</filter-name>
    <filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class>
    </filter>
    <!-- FilterDispatcher 用来初始化 strtus2 并且处理所有的 web 请求 -->
    <filter-mapping>
    <filter-name>struts2</filter-name>
    <url-pattern>/*</url-pattern>
    </filter-mapping>我的资源里面有个struts2的helloworld有兴趣去下载看看
      

  4.   

    这种问题一般都是包的问题。
    再你的程序中把
    commons-fileupload-1.2.1.jar
    commons-io-1.4.jar
    加进去再试试。
      

  5.   

    <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter </filter-class> 
    这是struts2.1.6的配置,我换成2.0的也出现同样的问题
    程序中的jar文件有commons-fileupload-1.2.1.jar,commons-io-1.3.2.jar,commons-logging-1.1.jar,freeer-2.3.13.jar,ognl-2.6.11.jar,struts2-core-2.1.6.jar,xwork-2.1.2.jar
      

  6.   

    找到了问题的所在,struts.xml配置:
    <struts>
        <constant name="struts.enable.DynamicMethodInvocation" value="false" />
        <constant name="struts.devMode" value="true" />
        <constant name="struts.ognl.allowStaticMethodAccess" value="true"></constant>
        <include file="/com/bjsxt/struts2/ognl/ognl.xml"/>
    </struts> 
    把<constant name="struts.devMode" value="true" />这个配置去掉就没事了,为什么启用struts开发模式就不行呢?我用的是MyEclipse7.5,tomcat6.0,struts是2.1.6的。往高手指点。
      

  7.   

      你设置了<constant name="struts.devMode" value="true" />
     解释如下: 
    意思是说如果你修改了struts.xml中的配置或一些资源文件,你不必每次都重启服务器
      
      

  8.   

    我的和楼主一样  我也开启了<constant name="struts.devMode" value="true" /> 
      但不一样的是  我的没报错...
      

  9.   

    找到答案了,这是struts2.1.6的一个bug,要想不出现问题,那么tomcat的安装路径就不能有空格,晕!
      

  10.   

    问题是tomcat安装是有空格导致的错误,把tomcat重新安装不要有文件夹都不要有空格就行,是2.1.6jar的一个bug 我就是这个问题 改了好了