2009-10-26 44 views
1

我在Spring 3.0.0.RC1中使用@PostConstruct註解(標記bean中的init方法)。我開始在碼頭這個Web應用程序,並得到以下異常:在Spring 3.0.0.RC1中使用@PostConstruct註釋

java.lang.NoSuchMethodError: org.springframework.core.OrderComparator.sort(Ljava/util/List;)V 
    at org.springframework.context.support.AbstractApplicationContext.invokeBeanFactoryPostProcessors(AbstractApplicationContext.java:520) 
    at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:366) 
    at org.springframework.web.context.ContextLoader.createWebApplicationContext(ContextLoader.java:270) 
    at org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java:197) 
    at org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java:47) 
    at org.mortbay.jetty.handler.ContextHandler.startContext(ContextHandler.java:548) 
    at org.mortbay.jetty.servlet.Context.startContext(Context.java:136) 
    at org.mortbay.jetty.webapp.WebAppContext.startContext(WebAppContext.java:1234) 
    at org.mortbay.jetty.handler.ContextHandler.doStart(ContextHandler.java:517) 
    at org.mortbay.jetty.webapp.WebAppContext.doStart(WebAppContext.java:460) 
    at org.gradle.api.plugins.jetty.JettyPluginWebAppContext.doStart(JettyPluginWebAppContext.java:140) 
    at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50) 
    at org.mortbay.jetty.handler.HandlerCollection.doStart(HandlerCollection.java:152) 
    at org.mortbay.jetty.handler.ContextHandlerCollection.doStart(ContextHandlerCollection.java:156) 
    at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50) 
    at org.mortbay.jetty.handler.HandlerCollection.doStart(HandlerCollection.java:152) 
    at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50) 
    at org.mortbay.jetty.handler.HandlerWrapper.doStart(HandlerWrapper.java:130) 
    at org.mortbay.jetty.Server.doStart(Server.java:222) 
    at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50) 
    at org.gradle.api.plugins.jetty.JettyPluginServer.start(JettyPluginServer.java:128) 
    at org.gradle.api.plugins.jetty.AbstractJettyRunTask.startJettyInternal(AbstractJettyRunTask.java:290) 
    at org.gradle.api.plugins.jetty.AbstractJettyRunTask.startJetty(AbstractJettyRunTask.java:245) 
    at org.gradle.api.plugins.jetty.AbstractJettyRunTask.start(AbstractJettyRunTask.java:216) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 
    at java.lang.reflect.Method.invoke(Method.java:597) 
    at org.codehaus.groovy.reflection.CachedMethod.invoke(CachedMethod.java:86) 
    at groovy.lang.MetaMethod.doMethodInvoke(MetaMethod.java:234) 
    at groovy.lang.MetaClassImpl.invokeMethod(MetaClassImpl.java:1049) 
    at groovy.lang.MetaClassImpl.invokeMethod(MetaClassImpl.java:880) 
    at groovy.lang.MetaClassImpl.invokeMethod(MetaClassImpl.java:706) 
    at org.gradle.api.DefaultTask.invokeMethod(DefaultTask.groovy) 
    at groovy.lang.GroovyObject$invokeMethod.call(Unknown Source) 
    at org.gradle.util.ReflectionUtil.invoke(ReflectionUtil.groovy:23) 
    at org.gradle.api.internal.project.AnnotationProcessingTaskFactory$2.execute(AnnotationProcessingTaskFactory.java:125) 
    at org.gradle.api.internal.project.AnnotationProcessingTaskFactory$2.execute(AnnotationProcessingTaskFactory.java:123) 
    at org.gradle.api.internal.AbstractTask.doExecute(AbstractTask.java:257) 
    at org.gradle.api.internal.AbstractTask.execute(AbstractTask.java:222) 
    at org.gradle.execution.DefaultTaskExecuter.executeTask(DefaultTaskExecuter.java:165) 
    at org.gradle.execution.DefaultTaskExecuter.doExecute(DefaultTaskExecuter.java:156) 
    at org.gradle.execution.DefaultTaskExecuter.execute(DefaultTaskExecuter.java:74) 
    at org.gradle.execution.TaskNameResolvingBuildExecuter.execute(TaskNameResolvingBuildExecuter.java:174) 
    at org.gradle.execution.DelegatingBuildExecuter.execute(DelegatingBuildExecuter.java:54) 
    at org.gradle.GradleLauncher.doBuildStages(GradleLauncher.java:165) 
    at org.gradle.GradleLauncher.doBuild(GradleLauncher.java:124) 
    at org.gradle.GradleLauncher.run(GradleLauncher.java:95) 
    at org.gradle.Main.execute(Main.java:100) 
    at org.gradle.Main.main(Main.java:43) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 
    at java.lang.reflect.Method.invoke(Method.java:597) 
    at org.gradle.BootstrapMain.main(BootstrapMain.java:50) 
failed [email protected] 

或者是否有人知道,如果它是在RC1中的錯誤,如果有一個變通?

回答

1

我知道這是一個古老的問題,但我仍然會發布我爲後代尋找的答案。

這是一個依賴性問題。在我的項目的依賴關係樹中,我注意到cxf-rt-transports-http-jetty依賴關係對spring-web.2.5.5具有傳遞依賴性。 OrderComparator.sort方法直到後來才實現,所以除非您爲POM添加Spring-web的新版本的直接依賴關係定義,否則spring將回退到jetty需要的較舊版本。

爲了解決這個問題,我將最新的spring-core和spring-web構件的依賴定義添加到了我的POM中。

相關問題