我正在将一个webapp从JBoss迁移到Embedded Tomcat。它适用于intellij但是当我使用java -jar myapplication.war运行war文件时,它会显示以下错误。谷歌搜索后,我找不到任何解决方案。这个问题似乎我有两个struts2核心jar或一些依赖冲突,但我只有一个jar。
示例项目here。
错误:
2017-12-11 10:58:24.527 ERROR 10296 --- [nio-8080-exec-1] o.apache.struts2.dispatcher.Dispatcher:Dispatcher初始化失败
com.opensymphony.xwork2.config.ConfigurationException:无法加载配置。 at com.opensymphony.xwork2.config.ConfigurationManager.getConfiguration(ConfigurationManager.java:70)〜[xwork-core-2.3.34.jar!/:2.3.34] at org.apache.struts2.dispatcher.Dispatcher.getContainer( Dispatcher.java:978)~ [struts2-core-2.3.34.jar!/:2.3.34] atg.apache.struts2.dispatcher.Dispatcher.init_PreloadConfiguration(Dispatcher.java:446)~ [struts2-core-2.3 .34.jar!/:2.3.34] org.apache.struts2.dispatcher.Dispatcher.init(Dispatcher.java:490)〜[struts2-core-2.3.34.jar!/:2.3.34] at org .apache.struts2.dispatcher.ng.InitOperations.initDispatcher(InitOperations.java:74)[struts2-core-2.3.34.jar!/:2.3.34] at org.apache.struts2.dispatcher.ng.servlet.StrutsServlet .init(StrutsServlet.java:54)[struts2-core-2.3.34.jar!/:2.3.34]在org.apache.catalina.core.StandardWrapper.initServlet(StandardWrapper.java:1183)[tomcat-embed- core-8.5.14.jar!/:8.5.14] at org.apache.catalina.core.StandardWrapper.allocate(StandardWrapper.java:795)[tomcat-embed-core-8.5.14.jar!/:8.5。 [14] at org.apache.catalina.core.S tandardWrapperValve.invoke(StandardWrapperValve.java:133)[tomcat-embed-core-8.5.14.jar!/:8.5.14] at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)[tomcat -embed-core-8.5.14.jar!/:8.5.14] at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:478)[tomcat-embed-core-8.5.14.jar!/ :8.5.14]在org.apache.catalina的org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:140)[tomcat-embed-core-8.5.14.jar!/:8.5.14]。 valve.ErrorReportValve.invoke(ErrorReportValve.java:80)[tomcat-embed-core-8.5.14.jar!/:8.5.14] at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87) [tomcat-embed-core-8.5.14.jar!/:8.5.14]在org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:342)[tomcat-embed-core-8.5.14.jar !/:8.5.14]在org.apache的org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:799) [tomcat-embed-core-8.5.14.jar!/:8.5.14]。 coyote.AbstractProcessorLight。 org.apache.coyote.AbstractProtocol $ ConnectionHandler.process(AbstractProtocol.java:861)[tomcat-embed]中的进程(AbstractProcessorLight.java:66)[tomcat-embed-core-8.5.14.jar!/:8.5.14] -core-8.5.14.jar!/:8.5.14] at org.apache.tomcat.util.net.NioEndpoint $ SocketProcessor.doRun(NioEndpoint.java:1455)[tomcat-embed-core-8.5.14.jar !/:8.5.14]在java的org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)[tomcat-embed-core-8.5.14.jar!/:8.5.14]。 util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)[na:1.8.0_131] at java.util.concurrent.ThreadPoolExecutor $ Worker.run(ThreadPoolExecutor.java:617)[na:1.8.0_131] at org。 apache.tomcat.util.threads.TaskThread $ WrappingRunnable.run(TaskThread.java:61)[tomcat-embed-core-8.5.14.jar!/:8.5.14] at java.lang.Thread.run(Thread。 java:748)[na:1.8.0_131]引起:com.opensymphony.xwork2.config.ConfigurationException:无法在com.opensymphony.xwor中加载bean:type:class:com.opensymphony.xwork2.ObjectFactory org.apache.struts2.config.StrutsXmlConfigurationProvider.register(StrutsXmlConfigurationProvider.java)中的k2.config.providers.XmlConfigurationProvider.register(XmlConfigurationProvider.java:247)〜[xwork-core-2.3.34.jar!/:2.3.34] :[102]〜[struts2-core-2.3.34.jar!/:2.3.34] at com.opensymphony.xwork2.config.impl.DefaultConfiguration.reloadContainer(DefaultConfiguration.java:240)~ [xwork-core-2.3。 34.jar!/:2.3.34]在com.opensymphony.xwork2.config.ConfigurationManager.getConfiguration(ConfigurationManager.java:67)〜[xwork-core-2.3.34.jar!/:2.3.34] ...省略了23个常见框架引起:com.opensymphony.xwork2.config.ConfigurationException:Bean类型类com.opensymphony.xwork2.ObjectFactory,名称为struts,已由bean加载 - jar:file:/ C:/ workspaces / workspace / pessoal /弹簧启动的struts2 /目标/弹簧引导struts2-0.0.1-SNAPSHOT.war /WEB-INF/lib/struts2-core-2.3.34.jar /struts-default.xml:!65: 72 at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.register(X mlConfigurationProvider.java:231)~ [xwork-core-2.3.34.jar!/:2.3.34] ...省略了26个常用帧
我的相关内容:
StrutsServlet
@WebServlet(urlPatterns = { "*.do" })
public class SBSStrutsServlet extends StrutsServlet {
private static final long serialVersionUID = 4919365268043339311L;
}
application.Java
@SpringBootApplication
@ServletComponentScan
public class Application extends SpringBootServletInitializer {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
在struts.xml
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
"http://struts.apache.org/dtds/struts-2.3.dtd">
<struts>
<constant name="struts.objectFactory" value="spring"/>
<package name="sbs" namespace="/sbs" extends="struts-default">
<action name="welcome" class="com.gbarbosa.sbs.controller.HelloWorldAction">
<result name="success">welcome.jsp</result>
</action>
</package>
</struts>
WEB-INF \ lib
asm-3.3.jar
asm-commons-3.3.jar
asm-tree-3.3.jar
classmate-1.3.3.jar
commons-fileupload-1.3.2.jar
commons-io-2.2.jar
commons-lang3-3.2.jar
ecj-4.5.1.jar
freemarker-2.3.26-incubating.jar
hibernate-validator-5.3.5.Final.jar
jackson-annotations-2.8.0.jar
jackson-core-2.8.8.jar
jackson-databind-2.8.8.jar
javassist-3.11.0.GA.jar
jboss-logging-3.3.1.Final.jar
jcl-over-slf4j-1.7.25.jar
jstl-1.2.jar
jul-to-slf4j-1.7.25.jar
log4j-api-2.7.jar
log4j-core-2.8.2.jar
log4j-over-slf4j-1.7.25.jar
logback-classic-1.1.11.jar
logback-core-1.1.11.jar
ognl-3.0.21.jar
slf4j-api-1.7.25.jar
snakeyaml-1.17.jar
spring-aop-4.3.8.RELEASE.jar
spring-beans-4.3.8.RELEASE.jar
spring-boot-1.5.3.RELEASE.jar
spring-boot-autoconfigure-1.5.3.RELEASE.jar
spring-boot-starter-1.5.3.RELEASE.jar
spring-boot-starter-logging-1.5.3.RELEASE.jar
spring-boot-starter-web-1.5.3.RELEASE.jar
spring-context-4.3.8.RELEASE.jar
spring-core-4.3.8.RELEASE.jar
spring-expression-4.3.8.RELEASE.jar
spring-web-4.3.8.RELEASE.jar
spring-webmvc-4.3.8.RELEASE.jar
struts2-core-2.3.34.jar
struts2-spring-plugin-2.3.34.jar
tomcat-embed-core-8.5.14.jar
tomcat-embed-el-8.5.14.jar
tomcat-embed-jasper-8.5.9.jar
validation-api-1.1.0.Final.jar
xwork-core-2.3.34.jar
WAR结构最终
META-INF
org
sbs
WEB-INF
我真的坚持这个和intellij它工作正常。我不知道为什么struts已经创建了一个名为struts的bean,并且类型为com.opensymphony.xwork2.ObjectFactory。
拜托,有人有任何想法吗?
我找到了解决方案。
虽然它看起来像一个重复的jar问题它不是。问题在于:tomcat容器为同一个文件提供了两个不同的路径。不同的前缀路径jar:file:/和jar:war:file:/。
名为spring的Bean类com.opensymphony.xwork2.ObjectFactory已经被bean加载 - jar:file:/ C:/target/spring-boot-struts2-0.0.1-SNAPSHOT.war!/ WEB-INF / lib / struts2-spring-plugin-2.3.34.jar!/struts-plugin.xml:29:132 - bean-jar:war:file:/ C:/target/spring-boot-struts2-0.0.1-SNAPSHOT *的.war / WEB-INF / lib目录/ Struts2的弹簧,插件-2.3.34.jar /struts-plugin.xml:29:132
为了解决这个问题,我刚刚将struts2-core和struts2-spring-plugin范围从编译改为提供。 spring-boot-maven-plugin将这些文件放在WEB-INF / lib下提供,然后当我使用java -jar myapplication.war运行时,这些jar在运行时提供。
要从maven项目制作可执行jar或war,你应该使用
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<executable>true</executable>
<classifier>boot</classifier>
</configuration>
</plugin>
它允许您重新打包war文件以使其可启动。你可以在这个页面或Spring Boot Maven plugin页面找到更多关于Usage的信息。
66.2 Packaging executable jar and war files
一旦
spring-boot-maven-plugin
被包含在你的pom.xml
中,它将自动尝试重写档案,使其可以使用spring-boot:repackage
目标执行。您应该使用通常的包装元素将项目配置为构建jar或war(视情况而定):<?xml version="1.0" encoding="UTF-8"?> <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"> <!-- ... --> <packaging>jar</packaging> <!-- ... --> </project>
在
package
阶段,Spring Boot将增强您现有的存档。您要启动的主类可以使用配置选项指定,也可以通过以常规方式向清单添加Main-Class
属性。如果您未指定主类,则插件将使用public static void main(String[] args)
方法搜索类。要构建和运行项目工件,可以键入以下内容:
$ mvn package $ java -jar target/mymodule-0.0.1-SNAPSHOT.jar