我是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

以下是项目结构

project_structure

下面是为maven构建下载的jar

maven_jars