使用ApacheIvy从3.0.5迁移到Spring3.1:java.lang.CompatibleClassChangeError:

使用ApacheIvy从3.0.5迁移到Spring3.1:java.lang.CompatibleClassChangeError:,spring,hibernate,maven-2,spring-security,dependency-management,Spring,Hibernate,Maven 2,Spring Security,Dependency Management,在过去的两周里,我一直在与ApacheIvy进行斗争,以管理依赖关系,但我一直无法理解大家在web上谈论的明显的易用性(一旦maven/gradle/ApacheIvy用于DM)。有人能帮忙看看我做错了什么吗?我会非常感激的 我正在尝试将现有的Spring/JPA Hibernate应用程序迁移到最新的Spring和Hibernate发行版: Spring 3.1.2 Spring Security 3.1.1 Hibernate 4.1 我的环境: Eclipse Helios Tomcat

在过去的两周里,我一直在与ApacheIvy进行斗争,以管理依赖关系,但我一直无法理解大家在web上谈论的明显的易用性(一旦maven/gradle/ApacheIvy用于DM)。有人能帮忙看看我做错了什么吗?我会非常感激的

我正在尝试将现有的Spring/JPA Hibernate应用程序迁移到最新的Spring和Hibernate发行版:

Spring 3.1.2
Spring Security 3.1.1
Hibernate 4.1
我的环境:

Eclipse Helios
Tomcat 7.23
ivy.xml:

<?xml version="1.0" encoding="ISO-8859-1"?>
<ivy-module version="2.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
   xsi:noNamespaceSchemaLocation="http://ant.apache.org/ivy/schemas/ivy.xsd">    <info
    organisation=""
    module="FocusIvy"
    status="integration">
</info>
<dependencies>  
    <dependency org="org.hibernate" name="com.springsource.org.hibernate.ejb" rev="4.1.0.Final" />
    <dependency org="org.hibernate" name="com.springsource.org.hibernate.annotations" rev="3.4.0.GA-A" />
    <dependency org="org.hibernate.common" name="com.springsource.org.hibernate.annotations.common" rev="4.1.0.Final" />
    <dependency org="org.hibernate" name="com.springsource.org.hibernate" rev="4.1.0.Final" />
    <dependency org="org.hibernate" name="com.springsource.org.hibernate.core" rev="4.1.0.Final" />
    <dependency org="org.hibernate" name="com.springsource.org.hibernate.validator" rev="4.2.0.Final" /> 

    <dependency org="org.springframework" name="org.springframework.core" rev="3.1.2.RELEASE" />
    <dependency org="org.springframework" name="org.springframework.beans" rev="3.1.2.RELEASE" />
    <dependency org="org.springframework" name="org.springframework.context" rev="3.1.2.RELEASE" />
    <dependency org="org.springframework" name="org.springframework.context.support" rev="3.1.2.RELEASE" />
    <dependency org="org.springframework" name="org.springframework.transaction" rev="3.1.2.RELEASE" />
    <dependency org="org.springframework" name="org.springframework.jdbc" rev="3.1.2.RELEASE" />
    <dependency org="org.springframework" name="org.springframework.expression" rev="3.1.2.RELEASE" />  
    <dependency org="org.springframework" name="org.springframework.aop" rev="3.1.2.RELEASE" />
    <dependency org="org.springframework" name="org.springframework.web" rev="3.1.2.RELEASE" /> 
    <dependency org="org.springframework" name="org.springframework.web.servlet" rev="3.1.2.RELEASE" /> 
    <dependency org="org.springframework" name="org.springframework.orm" rev="3.1.2.RELEASE" />

    <dependency org="org.springframework.security" name="org.springframework.security.core" rev="3.1.1.RELEASE" />      
    <dependency org="org.springframework.security" name="org.springframework.security.aspects" rev="3.1.1.RELEASE" />
    <dependency org="org.springframework.security" name="org.springframework.security.taglibs" rev="3.1.1.RELEASE" />
    <dependency org="org.springframework.security" name="org.springframework.security.web" rev="3.1.1.RELEASE" />
    <dependency org="org.springframework.security" name="org.springframework.security.annotation" rev="2.0.6.RELEASE" />

    <dependency org="javax.activation" name="com.springsource.javax.activation"
            rev="1.1.1" />
    <dependency org="net.sourceforge.cglib" name="com.springsource.net.sf.cglib" rev="2.2.0" />             
</dependencies> 
</ivy-module>

警告:无法加载类[org.springframework.instrument.classloading.jboss.JBossMCAdapter]以检查一个或多个ServletContentInitializer的@HandleTypes注释。java.lang.CompatibleClassChangeError:实现类

总之,ApacheTomcat服务器不是JBoss服务器


其次,这在spring框架内部似乎是一个合理的问题,因此,是时候看看在Tomcat而不是JBoss中加载spring所需的设置了。这可能很有用:尝试使用spring 3.1.1 jar,而不是3.1.1。同样的错误。首先,org.springframework.security.annotation已经重新打包到org.springframework.security.access.annotation,并且已经包含在core中,因此您不需要添加它。第二,从3.5版开始,hibernate注释包含在hibernate核心中,因此您不必再添加它。另外,您的web应用程序是否配置为Servlet 3.0?@Ravi感谢您的评论,我删除了隐式包含的依赖项,但是,同样的错误。关于Servlet3.0。我选择3.0作为“动态web模块版本”。另外,servlet有@WebServlet注释,我认为它只适用于3.0。
<?xml version="1.0" encoding="ISO-8859-1"?>
<ivysettings>
<settings defaultResolver="defaultChain"
    defaultConflictManager="all" />

<resolvers>
    <url name="com.springsource.repository.bundles.release">
        <ivy
            pattern="http://repository.springsource.com/ivy/bundles/release/[organisation]/[module]/[revision]/[artifact]-[revision].[ext]" />
        <artifact
            pattern="http://repository.springsource.com/ivy/bundles/release/[organisation]/[module]/[revision]/[artifact]-[revision].[ext]" />
    </url>

    <url name="com.springsource.repository.bundles.external">
        <ivy
            pattern="http://repository.springsource.com/ivy/bundles/external/[organisation]/[module]/[revision]/[artifact]-[revision].[ext]" />
        <artifact
            pattern="http://repository.springsource.com/ivy/bundles/external/[organisation]/[module]/[revision]/[artifact]-[revision].[ext]" />
    </url>
    <chain name="defaultChain" returnFirst="true">
        <resolver ref="com.springsource.repository.bundles.release" />
        <resolver ref="com.springsource.repository.bundles.external" />
    </chain>
</resolvers>
</ivysettings>
 WARNING: Unable to load class     [org.springframework.instrument.classloading.jboss.JBossMCAdapter] to check against the     @HandlesTypes annotation of one or more ServletContentInitializers.
 java.lang.IncompatibleClassChangeError: Implementing class
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClassCond(ClassLoader.java:632)
at java.lang.ClassLoader.defineClass(ClassLoader.java:616)
at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:141)
at org.apache.catalina.loader.WebappClassLoader.findClassInternal(WebappClassLoader.java:2823)
at org.apache.catalina.loader.WebappClassLoader.findClass(WebappClassLoader.java:1160)
at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1655)
at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1533)
at org.apache.catalina.startup.ContextConfig.checkHandlesTypes(ContextConfig.java:1988)
at org.apache.catalina.startup.ContextConfig.processAnnotationsStream(ContextConfig.java:1951)
at org.apache.catalina.startup.ContextConfig.processAnnotationsJar(ContextConfig.java:1840)
at org.apache.catalina.startup.ContextConfig.processAnnotationsUrl(ContextConfig.java:1808)
at org.apache.catalina.startup.ContextConfig.processAnnotations(ContextConfig.java:1794)
at org.apache.catalina.startup.ContextConfig.webConfig(ContextConfig.java:1214)
at org.apache.catalina.startup.ContextConfig.configureStart(ContextConfig.java:828)
at org.apache.catalina.startup.ContextConfig.lifecycleEvent(ContextConfig.java:302)
at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:119)
at org.apache.catalina.util.LifecycleBase.fireLifecycleEvent(LifecycleBase.java:90)
at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5148)
at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1525)
at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1515)
at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:303)
at java.util.concurrent.FutureTask.run(FutureTask.java:138)
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
at java.lang.Thread.run(Thread.java:662)
 Oct 16, 2012 2:31:42 PM org.apache.catalina.startup.ContextConfig checkHandlesTypes
 WARNING: Unable to load class      [org.springframework.instrument.classloading.jboss.JBossModulesAdapter] to check against   the @HandlesTypes annotation of one or more ServletContentInitializers.
java.lang.IncompatibleClassChangeError: Implementing class
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClassCond(ClassLoader.java:632)
at java.lang.ClassLoader.defineClass(ClassLoader.java:616)
at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:141)
at org.apache.catalina.loader.WebappClassLoader.findClassInternal(WebappClassLoader.java:2823)
at org.apache.catalina.loader.WebappClassLoader.findClass(WebappClassLoader.java:1160)
at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1655)
at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1533)
at org.apache.catalina.startup.ContextConfig.checkHandlesTypes(ContextConfig.java:1988)
at org.apache.catalina.startup.ContextConfig.processAnnotationsStream(ContextConfig.java:1951)
at org.apache.catalina.startup.ContextConfig.processAnnotationsJar(ContextConfig.java:1840)
at org.apache.catalina.startup.ContextConfig.processAnnotationsUrl(ContextConfig.java:1808)
at org.apache.catalina.startup.ContextConfig.processAnnotations(ContextConfig.java:1794)
at org.apache.catalina.startup.ContextConfig.webConfig(ContextConfig.java:1214)
at org.apache.catalina.startup.ContextConfig.configureStart(ContextConfig.java:828)
at org.apache.catalina.startup.ContextConfig.lifecycleEvent(ContextConfig.java:302)
at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:119)
at org.apache.catalina.util.LifecycleBase.fireLifecycleEvent(LifecycleBase.java:90)
at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5148)
at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1525)
at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1515)
at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:303)
at java.util.concurrent.FutureTask.run(FutureTask.java:138)
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
at java.lang.Thread.run(Thread.java:662)
   Oct 16, 2012 2:31:44 PM org.apache.catalina.startup.ContextConfig checkHandlesTypes