运行jsp文件时出错。由于这个动态Web项目是使用strut2 spring3 hibernate4完成的

时间:2013-08-05 16:10:24

标签: java struts2 classnotfoundexception spring-3 hibernate-4.x

实际上我正在尝试使用Spring3和Hibernate4实现Struts2。 当我启动Apache Tomcat服务器并运行index.jsp文件时,它会给我以下错误。

SEVERE: Exception starting filter struts2
java.lang.ClassNotFoundException: org.apache.struts2.dispatcher.FilterDispatcher
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1714)
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1559)
    at org.apache.catalina.core.DefaultInstanceManager.loadClass(DefaultInstanceManager.java:527)
    at org.apache.catalina.core.DefaultInstanceManager.loadClassMaybePrivileged(DefaultInstanceManager.java:509)
    at org.apache.catalina.core.DefaultInstanceManager.newInstance(DefaultInstanceManager.java:137)
    at org.apache.catalina.core.ApplicationFilterConfig.getFilter(ApplicationFilterConfig.java:260)
    at org.apache.catalina.core.ApplicationFilterConfig.<init>(ApplicationFilterConfig.java:107)
    at org.apache.catalina.core.StandardContext.filterStart(StandardContext.java:4775)
    at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5452)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1559)
    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1549)
    at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source)
    at java.util.concurrent.FutureTask.run(Unknown Source)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
    at java.lang.Thread.run(Unknown Source)

Aug 05, 2013 9:24:48 PM org.apache.catalina.core.StandardContext startInternal
SEVERE: Error filterStart
Aug 05, 2013 9:24:48 PM org.apache.catalina.core.StandardContext startInternal
SEVERE: Context [/hibernate_strut_spring] startup failed due to previous errors
Aug 05, 2013 9:24:48 PM org.apache.coyote.AbstractProtocol start
INFO: Starting ProtocolHandler ["http-apr-8080"]
Aug 05, 2013 9:24:48 PM org.apache.coyote.AbstractProtocol start
INFO: Starting ProtocolHandler ["ajp-apr-8009"]
Aug 05, 2013 9:24:48 PM org.apache.catalina.startup.Catalina start
INFO: Server startup in 425 ms

请帮助我。我是这个主题的初学者。请帮帮我朋友。

我在WEB-INF / lib中添加了所有相关的jar文件 它显示了一些其他错误,如下所示

SEVERE: Exception starting filter struts2
java.lang.NoSuchMethodError: com.opensymphony.xwork2.config.ConfigurationManager.addConfigurationProvider(Lcom/opensymphony/xwork2/config/ConfigurationProvider;)V
    at org.apache.struts2.dispatcher.Dispatcher.init_DefaultProperties(Dispatcher.java:310)
    at org.apache.struts2.dispatcher.Dispatcher.init(Dispatcher.java:411)
    at org.apache.struts2.dispatcher.ng.InitOperations.initDispatcher(InitOperations.java:69)
    at org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter.init(StrutsPrepareAndExecuteFilter.java:51)
    at org.apache.catalina.core.ApplicationFilterConfig.initFilter(ApplicationFilterConfig.java:281)
    at org.apache.catalina.core.ApplicationFilterConfig.getFilter(ApplicationFilterConfig.java:262)
    at org.apache.catalina.core.ApplicationFilterConfig.<init>(ApplicationFilterConfig.java:107)
    at org.apache.catalina.core.StandardContext.filterStart(StandardContext.java:4775)
    at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5452)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1559)
    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1549)
    at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source)
    at java.util.concurrent.FutureTask.run(Unknown Source)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
    at java.lang.Thread.run(Unknown Source)

Aug 05, 2013 9:46:10 PM org.apache.catalina.core.StandardContext startInternal
SEVERE: Error filterStart
Aug 05, 2013 9:46:10 PM org.apache.catalina.core.StandardContext startInternal
SEVERE: Context [/hibernate_strut_spring] startup failed due to previous errors
Aug 05, 2013 9:46:10 PM org.apache.coyote.AbstractProtocol start
INFO: Starting ProtocolHandler ["http-apr-8080"]
Aug 05, 2013 9:46:10 PM org.apache.coyote.AbstractProtocol start
INFO: Starting ProtocolHandler ["ajp-apr-8009"]
Aug 05, 2013 9:46:10 PM org.apache.catalina.startup.Catalina start
INFO: Server startup in 2836 ms

web.xml文件

<?xml version="1.0" encoding="UTF-8"?>

<web-app id="WebApp_ID" 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">
    <display-name>hibernate_strut_spring</display-name>
    <welcome-file-list>
        <welcome-file>index.jsp</welcome-file>
    </welcome-file-list>
    <filter>
        <filter-name>struts2</filter-name>
            <filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class> 
    </filter>
    <filter-mapping>
        <filter-name>struts2</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>
</web-app>

3 个答案:

答案 0 :(得分:1)

在项目中使用相同版本的struts jar。我想你已经使用了不同的版本和你也错过了一些罐子。

答案 1 :(得分:0)

struts jar struts2-core-XXXX.jar其中XXXX表示版本需要找到应用程序的类路径。

这可以通过将其包含在WEB-INF/lib

中来实现

答案 2 :(得分:0)

如果您使用的是Eclipse,请执行CTRL + SHIFT +T并输入FilterDispatcherand,看看您是否可以在窗口中找到struts2-core-requiredVersion.jar。很可能你不会这就是为什么你得到错误的原因。你需要在ProjectDirectory/WEB-INF/lib下添加这个jar。

如果您使用的是maven,请添加以下依赖项

 <dependency>
      <groupId>org.apache.struts</groupId>
      <artifactId>struts2-core</artifactId>
      <version>latestVersion</version>
    </dependency>