2014-01-12 31 views
0

我試圖獲得一個基本的Struts2應用程序(使用tomcat,使用maven構建)啓動並運行。 Tomcat和Maven都能正常工作;該頁面通常是在我的web.xml(位於src/main/webapp/WEB-INF)中添加一些Struts過濾器之前提供的。下面是我的web.xml代碼:添加Struts2過濾器導致空白頁面

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

    <display-name>app</display-name> 
    <description>tagline</description> 

    <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> 
</web-app> 

此外,這裏是我的struts.xml的代碼(位於的src/main /資源:

<?xml version="1.0" encoding="UTF-8"?> 
<!DOCTYPE struts PUBLIC 
    "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN" 
    "http://struts.apache.org/dtds/struts-2.0.dtd"> 

<struts> 
    <constant name="struts.devMode" value="true" /> 
    <package name="app" extends="struts-default"> 
     <action name="index"> 
      <result>/index.jsp</result> 
     </action> 
    </package> 
</struts> 

我catalina.log具有以下錯誤信息:

12-Jan-2014 15:33:20.256 SEVERE [localhost-startStop-16] org.apache.catalina.core.StandardContext.startInternal Error filterStart 
12-Jan-2014 15:33:20.256 SEVERE [localhost-startStop-16] org.apache.catalina.core.StandardContext.startInternal Context [/app] startup failed due to previous errors 

我剛剛注意到目前在catalina.log另一個問題,只顯示在啓動時的tomcat:

13-Jan-2014 20:19:57.465 SEVERE [main] org.apache.catalina.core.AprLifecycleListener.init An incompatible version 1.1.27 of the APR based Apache Tomcat Native library is installed, while Tomcat requires version 1.1.29 

真的很奇怪的是我的apache-tomcat-ver/bin中的tomcat-native.tar.gz是版本1.1.29。

此外,我localhost.log有錯誤的一個爛攤子:

13-Jan-2014 20:20:04.780 SEVERE [localhost-startStop-1] org.apache.catalina.core.StandardContext.filterStart Exception starting filter struts2 
Unable to load configuration. - bean - jar:file:/usr/local/apache-tomcat/apache-tomcat-8.0.0-RC10/webapps/symIOsis/WEB-INF/lib/struts2-portlet-plugin-2.3.16.jar!/struts-plugin.xml:31:133 
    at org.apache.struts2.dispatcher.Dispatcher.init(Dispatcher.java:501) 
    at org.apache.struts2.dispatcher.ng.InitOperations.initDispatcher(InitOperations.java:74) 
    at org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter.init(StrutsPrepareAndExecuteFilter.java:57) 
    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:4646) 
    at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5274) 
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150) 
    at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:726) 
    at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:702) 
    at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:699) 
    at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:977) 
    at org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1763) 
    at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:471) 
    at java.util.concurrent.FutureTask.run(FutureTask.java:262) 
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145) 
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615) 
    at java.lang.Thread.run(Thread.java:744) 
Caused by: Unable to load configuration. - bean - jar:file:/usr/local/apache-tomcat/apache-tomcat-8.0.0-RC10/webapps/symIOsis/WEB-INF/lib/struts2-portlet-plugin-2.3.16.jar!/struts-plugin.xml:31:133 
    at com.opensymphony.xwork2.config.ConfigurationManager.getConfiguration(ConfigurationManager.java:70) 
    at org.apache.struts2.dispatcher.Dispatcher.init_PreloadConfiguration(Dispatcher.java:445) 
    at org.apache.struts2.dispatcher.Dispatcher.init(Dispatcher.java:489) 
    ... 18 more 
Caused by: Unable to load bean: type:org.apache.struts2.components.UrlRenderer class:org.apache.struts2.components.PortletUrlRenderer - bean - jar:file:/usr/local/apache-tomcat/apache-tomcat-8.0.0-RC10/webapps/symIOsis/WEB-INF/lib/struts2-portlet-plugin-2.3.16.jar!/struts-plugin.xml:31:133 
    at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.register(XmlConfigurationProvider.java:245) 
    at org.apache.struts2.config.StrutsXmlConfigurationProvider.register(StrutsXmlConfigurationProvider.java:102) 
    at com.opensymphony.xwork2.config.impl.DefaultConfiguration.reloadContainer(DefaultConfiguration.java:234) 
    at com.opensymphony.xwork2.config.ConfigurationManager.getConfiguration(ConfigurationManager.java:67) 
    ... 20 more 
Caused by: java.lang.NoClassDefFoundError: javax/portlet/PortletMode 
    at java.lang.Class.getDeclaredConstructors0(Native Method) 
    at java.lang.Class.privateGetDeclaredConstructors(Class.java:2493) 
    at java.lang.Class.getDeclaredConstructors(Class.java:1901) 
    at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.register(XmlConfigurationProvider.java:235) 
    ... 23 more 
Caused by: java.lang.ClassNotFoundException: javax.portlet.PortletMode 
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1286) 
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1128) 
     ... 27 more 

對我來說,這看起來像一個依賴的問題,但是struts2-portlet-plugin-2.3.16.java存在於該位置。有誰知道如何解決這個問題?

編輯:我還添加了struts2-portlet-plugin作爲maven依賴項,希望它能解決問題。無濟於事,同樣的錯誤仍在出現。

而且,這裏的請求的pom.xml:

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> 
    <modelVersion>4.0.0</modelVersion> 

    <groupId>com.company.webapp</groupId> 
    <artifactId>webapp</artifactId> 
    <version>0.0.1-SNAPSHOT</version> 
    <packaging>war</packaging> 

    <name>webapp</name> 
    <url>http://maven.apache.org</url> 
    <properties> 
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> 
    </properties> 

    <build> 
     <finalName>app</finalName> 
    </build> 

    <dependencies> 
    <dependency> 
     <groupId>junit</groupId> 
     <artifactId>junit</artifactId> 
     <version>4.11</version> 
     <scope>test</scope> 
     </dependency> 
    <dependency> 
     <groupId>org.apache.struts</groupId> 
     <artifactId>struts2-core</artifactId> 
     <version>2.3.16</version> 
    </dependency> 
    <dependency> 
     <groupId>log4j</groupId> 
     <artifactId>log4j</artifactId> 
     <version>1.2.17</version> 
    </dependency> 
    <dependency> 
     <groupId>org.apache.struts</groupId> 
     <artifactId>struts2-portlet-plugin</artifactId> 
     <version>2.3.16</version> 
    </dependency> 
    </dependencies> 
</project> 
+1

請顯示完整的堆棧跟蹤。 –

+0

使用struts2所需的唯一依賴是struts2-core之一(org.apache.struts | struts2-core | 2.3.16)。你也可以使用tomcat-maven-plugin進行本地測試(org.apache.tomcat.maven | tomcat6-maven-plugin | 2.2),然後使用mvn tomcat:在你的項目位置運行。否則,根據你發佈的內容(如果在src/main/webapp中有一個index.jsp),你的web.xml或你的struts.xml中沒有任何問題,並且它們位於正確的位置。完整的stacktrace + pom可以方便地查看。 –

+0

如果你的應用服務器是tomcat,你爲什麼需要portlet插件? –

回答

1

大爲頭痛和大量的圈之後,我似乎已經想通了這個問題。顯然,使用maven構建時,我不需要將分佈式struts-ver/lib中的.jars複製到我的WEB-INF/lib文件夾中。這總是很簡單,呃?