我是Spring的新手,我目前正在使用Spring 4
战争部署到JCS-SaaS( Cloud 端)后,我遇到了以下错误:
[2016-11-08T12:50:06.686 00:00] [INCIDENT_ERROR] 1 [使用问题键创建的事件22“BEA-101216 [HTTP]”] [2016-11-08T12:50:06.547 00:00]错误[对于任务'71'执行ID为'3634255956252836'的部署请求时发生故障 . 错误是:'weblogic.application.ModuleException:[HTTP:101216] Servlet:“pepsiServlet”在Web应用程序启动时无法预加载:“test4.war” . [org.springframework.beans.factory.BeanDefinitionStoreException:解析XML的意外异常来自类路径资源的文档[pepsiServlet-context.xml];嵌套异常是java.lang.NoSuchMethodError:org.springframework.beans.MutablePropertyValues.add(Ljava / lang / String; Ljava / lang / Object;)Lorg / springframework / beans / MutablePropertyValues;
的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/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.itc</groupId>
<artifactId>pepsiIndIntegration</artifactId>
<packaging>war</packaging>
<version>0.0.1-SNAPSHOT</version>
<name>pepsiIndIntegration Maven Webapp</name>
<url>http://maven.apache.org</url>
<properties>
<jdk.version>1.7</jdk.version>
<spring.version>4.3.3.RELEASE</spring.version>
<slf4j.version>1.7.21</slf4j.version>
<log4j.version>1.2.17</log4j.version>
<apache.commons.version>3.5</apache.commons.version>
<cxf.version>3.1.8</cxf.version>
</properties>
<dependencies>
<!-- JUnit Dependency -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<scope>test</scope>
</dependency>
<!-- Spring Dependencies -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-tx</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context-support</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>cglib</groupId>
<artifactId>cglib</artifactId>
<version>3.2.4</version>
</dependency>
<!-- Logging Dependencies -->
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>${slf4j.version}</version>
</dependency>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>${log4j.version}</version>
</dependency>
<!-- Spring MVC -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-tx</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context-support</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>${spring.version}</version>
</dependency>
<!-- Org Apache Commons -->
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-lang3</artifactId>
<version>${apache.commons.version}</version>
</dependency>
<!-- Oracle Driver Dependency -->
<!-- <dependency> <groupId>oracle</groupId> <artifactId>ojdbc6</artifactId>
<version>1.0</version> <scope>system</scope> <systemPath>${oracle.driver.path}</systemPath>
</dependency> -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
</dependency>
<!-- Dependency for common file upload -->
<dependency>
<groupId>commons-fileupload</groupId>
<artifactId>commons-fileupload</artifactId>
<version>1.3.1</version>
</dependency>
<dependency>
<groupId>commons-io</groupId>
<artifactId>commons-io</artifactId>
<version>2.4</version>
</dependency>
<dependency>
<groupId>com.jcraft</groupId>
<artifactId>jsch</artifactId>
<version>0.1.54</version>
</dependency>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-frontend-jaxws</artifactId>
<version>${cxf.version}</version>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-transports-http</artifactId>
<version>${cxf.version}</version>
<scope>runtime</scope>
</dependency>
</dependencies>
<build>
<finalName>pepsiIndIntegration</finalName>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.2</version>
<configuration>
<source>${jdk.version}</source>
<target>${jdk.version}</target>
</configuration>
</plugin>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>sonar-maven-plugin</artifactId>
<version>2.5</version>
</plugin>
<plugin>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-xjc-plugin</artifactId>
<version>${cxf.version}</version>
<configuration>
<extensions>
<extension>org.apache.cxf.xjcplugins:cxf-xjc-dv:3.1.8</extension>
</extensions>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-codegen-plugin</artifactId>
<version>3.1.8</version>
<executions>
<execution>
<goals>
<goal>wsdl2java</goal>
</goals>
<configuration>
<sourceRoot>${basedir}/target/generated-sources/cxf/wsdl2java</sourceRoot>
<wsdlRoot>${wsdls}</wsdlRoot>
<wsdlOptions>
<wsdlOption>
<wsdl>https://someurl/abc/xyz?wsdl</wsdl>
<extraargs>
<extraarg>-client</extraarg>
</extraargs>
</wsdlOption>
</wsdlOptions>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
</project>
下面是web.xml
<!DOCTYPE web-app PUBLIC
"-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
"http://java.sun.com/dtd/web-app_2_3.dtd" >
<web-app>
<display-name>Archetype Created Web Application</display-name>
<!-- Loading Beans -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>
classpath:pepsiBeans.xml
</param-value>
</context-param>
<!-- Spring Dispatched Servlet -->
<servlet>
<servlet-name>pepsiServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:pepsiServlet-context.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>pepsiServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
下面是我的pepsiServlet-context.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans:beans xmlns:beans="http://www.springframework.org/schema/beans"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:tx="http://www.springframework.org/schema/tx" xmlns:task="http://www.springframework.org/schema/task"
xmlns:util="http://www.springframework.org/schema/util"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.3.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.3.xsd
http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.3.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.3.xsd
http://www.springframework.org/schema/task http://www.springframework.org/schema/task/spring-task-4.3.xsd
http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-4.3.xsd">
<context:component-scan base-package="com.itc.pepsi" />
<!-- DispatcherServlet Context: defines this servlet's request-processing
infrastructure -->
<!-- Enables the Spring MVC @Controller programming model -->
<mvc:annotation-driven />
<!-- Enable Annotation based Declarative Transaction Management -->
<tx:annotation-driven proxy-target-class="true"
transaction-manager="transactionManager" />
<!-- Creating TransactionManager Bean, since JDBC we are creating of type
DataSourceTransactionManager -->
<!-- <beans:bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<beans:property name="dataSource" ref="dataSource" /> </beans:bean> -->
<!-- Handles HTTP GET requests for /resources/** by efficiently serving
up static resources in the ${webappRoot}/resources directory -->
<mvc:resources mapping="/resources/**" location="/resources/"/>
<!-- Initialization for data source -->
<!-- <beans:bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<beans:property name="driverClassName" value="oracle.jdbc.driver.OracleDriver"
/> <beans:property name="url" value="jdbc:oracle:thin@hostname:port:service/sid"
/> <beans:property name="username" value="USER_NAME" /> <beans:property name="password"
value="PASSWORD" /> </beans:bean> -->
<beans:bean id="messageSource"
class="org.springframework.context.support.ReloadableResourceBundleMessageSource">
<beans:property name="basename" value="classpath:ApplicationMessages" />
<beans:property name="defaultEncoding" value="UTF-8" />
</beans:bean>
<task:annotation-driven scheduler="scheduler"
executor="executor" />
<task:scheduler id="scheduler" pool-size="10" />
<task:executor id="executor" pool-size="10" />
<beans:bean id="pepsiIntgService" class="com.itc.pepsi.bo.pepsiIntgService">
</beans:bean>
<task:scheduled-tasks scheduler="scheduler">
<task:scheduled ref="pepsiIntgService" method="readFile"
cron="${cronstring}" />
</task:scheduled-tasks>
<!-- <bean id="taskExecutor" class="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor">
<property name="corePoolSize" value="5" /> <property name="maxPoolSize" value="10"
/> <property name="queueCapacity" value="25" /> </bean> <bean id="taskExecutorExample"
class="TaskExecutorExample"> <constructor-arg ref="taskExecutor" /> </bean> -->
</beans:beans>
以下是部署到JCS-SaaS后的日志
[2016-11-08T12:50:06.686 00:00] [INCIDENT_ERROR] 1 [使用问题键创建的事件22“BEA-101216 [HTTP]”] [2016-11-08T12:50:06.547 00:00]错误[对于任务'71'执行ID为'3634255956252836'的部署请求时发生故障 . 错误是:'weblogic.application.ModuleException:[HTTP:101216] Servlet:“pepsiServlet”在Web应用程序启动时无法预加载:“test4.war” . [org.springframework.beans.factory.BeanDefinitionStoreException:解析XML的意外异常来自类路径资源的文档[pepsiServlet-context.xml];嵌套异常是java.lang.NoSuchMethodError:org.springframework.beans.MutablePropertyValues.add(Ljava / lang / String; Ljava / lang / Object;)Lorg / springframework / beans / MutablePropertyValues;位于org.springframework.beans.factory org.springframework.beans.factory文件中的org.springframework.beans.factory.xml.XmlBeanDefinitionReader.loadBeanDefinitions(XmlBeanDefinitionReader.java:342)中的org.springframework.beans.factory.xml.XmlBeanDefinitionReader.doLoadBeanDefinitions(XmlBeanDefinitionReader.java:420)位于org.springframework.beans.factory.support.AbstractBeanDefinitionReader.loadBeanDefinitions(AbstractBeanDefinitionReader)的org.springframework.beans.factory.support.AbstractBeanDefinitionReader.loadBeanDefinitions(AbstractBeanDefinitionReader.java:143)中的.xml.XmlBeanDefinitionReader.loadBeanDefinitions(XmlBeanDefinitionReader.java:310) .java:178)org.springframework.beans.factory.support.AbstractBeanDefinitionReader.loadBeanDefinitions(AbstractBeanDefinitionReader.java:149)org.springframework.web.context.support.XmlWebApplicationContext.loadBeanDefinitions(XmlWebApplicationContext.java:124)at org . springframework.web.context.support.XmlWebApplicationContext.loadBeanDefinitions(XmlWebApplicationContext.java:9 2)org.springframework.context上的org.springframework.context.support.AbstractRefreshableApplicationContext.refreshBeanFactory(AbstractRefreshableApplicationContext.java:123)org.springframework.context上的org.springframework.context.support.AbstractApplicationContext.obtainFreshBeanFactory(AbstractApplicationContext.java:422),AbstractApplicationContext org.springframework.web.servlet.FrameworkServlet.createWebApplicationContext(FrameworkServlet.java:402)中的.refresh(AbstractApplicationContext.java:352)org.springframework.web.servlet.FrameworkServlet.initWebApplicationContext(FrameworkServlet.java:316)at org . springframework.web.servlet.FrameworkServlet.initServletBean(FrameworkServlet.java:282)atg.springframework.web.servlet.HttpServletBean.init(HttpServletBean.java:126)at javax.servlet.GenericServlet.init(GenericServlet.java:241)在weblogic.servlet.internal.StubSecurityHelper $ ServletInitAction.run(StubSecurityHelper.java:283)at weblogic.security.acl.internal.AuthenticatedSubject.doAs(Authen) ticatedSubject.java:321)at weblogic.security.securityManager.runAs(SecurityManager.java:120)at weblogic.servome.StubSecurityHelper.createServlet(StubSecurityHelper.java:64)at weblogic.servlet.internal.StubLifecycleHelper.createOneInstance (StubLifecycleHelper.java:58)位于weblogic.servlet.internal.Web上的weblogic.servlet.inub.上传,Web目录中的weblogic.servlet.internal.Serub上的weblogic.servlet.internal.Serub上的weblogic.servlet.internal.ServletStubImpl.prepareServlet(ServletStubImpl.java:539) . (StubLifecycleHelper.java:48) (WebAppServletContext.java:2037)atweblogic.servlet.internal.Web上的Weblogic.servlet.internal.Web上的Weblogic.servlet.internal.WebAppServletContext.preloadResources(WebAppServletContext.java:1930)中的weblogic.servlet.internal.WebAppServletContext.loadServletsOnStartup(WebAppServletContext.java:2011)(WebAppServletContext.java:3226) at weblogic.servlet.internal.WebAppModule.startContexts(WebAppModule.java:1529)at weblogic.servlet.internal.WebAppModule.start(WebAppModule.java:488)at weblogic.application.internal.flow.ModuleStateDriver $ 3.next(ModuleStateDriver . java:425)at weblogic.application.utils.StateMachineDriver.nextState(StateMachineDriver.java:52)at weblogic.application.internal.flow.ModuleStateDriver.start(ModuleStateDriver.java:119)at weblogic.application.internal.flow.ScopedModuleDriver .start(ScopedModuleDriver.java:200)at weblogic.application.internal.flow.ModuleListenerInvoker.start(ModuleListenerInvoker.java:247)at weblogic.application.internal.flow.ModuleStateDriver $ 3.next(ModuleStateDriver.java:425)at weblogic . weblogic.application.internal.flow.StartModulesFlow.activate(StartModulesFlow.java)中的weblogic.application.internal.flow.ModuleStateDriver.start(ModuleStateDriver.java:119)中的application.utils.StateMachineDriver.nextState(StateMachineDriver.java:52) 27)weblogic.application.internal.BaseDeployment $ 2.next(BaseDeployment.java:671)at weblogic.application.utils.StateMachineDriver.nextState(StateMachineDriver.java:52)at weblogic.application.internal.BaseDeployment.activate(BaseDeployment . java:212)at weblogic.application.internal.SingleModuleDeployment.activate(SingleModuleDeployment.java:44)at weblogic.application.internal.DeploymentStateChecker.activate(DeploymentStateChecker.java:161)at weblogic.deploy.internal.targetserver.AppContainerInvoker.activate (AppContainerInvoker.java:84)at weblogic.deploy.internal.targetserver.operations.AbstractOperation.activate(AbstractOperation.java:573)at weblogic.deploy.internal.targetserver.operations.ActivateOperation.activateDeployment(Activa teOperation.java:150)at weblogic.deploy.internal.targetserver.operations.ActivateOperation.doCommit(ActivateOperation.java:116)at weblogic.deploy.internal.targetserver.operations.AbstractOperation.commit(AbstractOperation.java:327)at weblogic .deploy.internal.targetserver.DeploymentManager.handleDeploymentCommit(DeploymentManager.java:849)位于weblogic.deploy.internal.targetserver.DeployManager.exep . .loga:441)at weblogic.deploy.internal.targetserver.DeploymentServiceDispatcher.commit(DeploymentServiceDispatcher.java:163)at weblogic.deploy.service.internal.targetserver.DeploymentReceiverCallbackDeliverer.doCommitCallback(DeploymentReceiverCallbackDeliverer.java:217)at weblogic.deploy . service.internal.targetserver.DeploymentReceiverCallbackDeliverer.access $ 100(DeploymentReceiverCallbackDeliverer.java:14)at weblogic.deploy.service.internal.target server.DeploymentReceiverCallbackDeliverer $ 2.run(DeploymentReceiverCallbackDeliverer.java:69)at weblogic.work.SelfTuningWorkManagerImpl $ WorkAdapterImpl.run(SelfTuningWorkManagerImpl.java:550)at weblogic.work.ExecuteThread.execute(ExecuteThread.java:268)at weblogic.work . ExecuteThread.run(ExecuteThread.java:226)引起:java.lang.NoSuchMethodError:org.springframework.beans.MutablePropertyValues.add(Ljava / lang / String; Ljava / lang / Object;)Lorg / springframework / beans / MutablePropertyValues;在org.springframework.beans.factory org.springframework.beans.factory(位于org.springframework.beans.factory.xml.BeanDefinitionParserDelegate.parseCustomElement(BeanDefinitionParserDelegate)的org.springframework.beans.factory.xml.BeanDefinitionParserDelegate.parseCustomElement(BeanDefinitionParserDelegate.java:1297)中的.xml.NamespaceHandlerSupport.parse(NamespaceHandlerSupport.java:69)的.java:1287)处org.springframework.beans.factory.xml.DefaultBeanDefinitionDocumentReader.registerBeanDefinitions(DefaultBeanDefinitionDocumentReader.java:92)在org.springframework.beans.factory.xml.DefaultBeanDefinitionDocumentReader.parseBeanDefinitions(DefaultBeanDefinitionDocumentReader.java:135)Org.springframework.beans.factory.xml.XmlBeanDefinitionReader.registerBeanDefinitions(XmlBeanDefinitionReader.java:507)org.springframework.beans.factory.xml.XmlBeanDefinitionReader.doLoadBeanDefinitions(XmlBeanDefinitionReader.java:398)... 57 more':TRACE
以下是项目结构
下面是为maven构建下载的jar