IBM MQ 與spring整合後JAR的相關衝突問題

昨天寫了個《Ispring監聽與IBM MQ JMS整合》,其中這只是通過spring配置,但是真正與業務及DAO實現的時候,就得再整合一下

當把相關的MQ 相關jar引進去的時候,再運行原來項目單元測試時(junnit 4 ),出現:

java.lang.NoSuchMethodError: org.springframework.beans.BeanUtils.instantiateClass(Ljava/lang/Class;Ljava/lang/Class;)Ljava/lang/Object;
	at org.springframework.test.context.ContextLoaderUtils.resolveContextLoader(ContextLoaderUtils.java:118)
	at org.springframework.test.context.ContextLoaderUtils.buildMergedContextConfiguration(ContextLoaderUtils.java:594)
	at org.springframework.test.context.ContextLoaderUtils.buildMergedContextConfiguration(ContextLoaderUtils.java:560)
	at org.springframework.test.context.TestContext.<init>(TestContext.java:99)
	at org.springframework.test.context.TestContextManager.<init>(TestContextManager.java:117)
	at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.createTestContextManager(SpringJUnit4ClassRunner.java:119)
	at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.<init>(SpringJUnit4ClassRunner.java:108)
	at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
	at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39)
	at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27)
	at java.lang.reflect.Constructor.newInstance(Constructor.java:513)
	at org.junit.internal.builders.AnnotatedBuilder.buildRunner(AnnotatedBuilder.java:29)
	at org.junit.internal.builders.AnnotatedBuilder.runnerForClass(AnnotatedBuilder.java:21)
	at org.junit.runners.model.RunnerBuilder.safeRunnerForClass(RunnerBuilder.java:59)
	at org.junit.internal.builders.AllDefaultPossibilitiesBuilder.runnerForClass(AllDefaultPossibilitiesBuilder.java:26)
	at org.junit.runners.model.RunnerBuilder.safeRunnerForClass(RunnerBuilder.java:59)
	at org.junit.internal.requests.ClassRequest.getRunner(ClassRequest.java:26)
	at org.junit.internal.requests.FilterRequest.getRunner(FilterRequest.java:31)
	at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.<init>(JUnit4TestReference.java:33)
	at org.eclipse.jdt.internal.junit4.runner.JUnit4TestMethodReference.<init>(JUnit4TestMethodReference.java:25)
	at org.eclipse.jdt.internal.junit4.runner.JUnit4TestLoader.createTest(JUnit4TestLoader.java:54)
	at org.eclipse.jdt.internal.junit4.runner.JUnit4TestLoader.loadTests(JUnit4TestLoader.java:38)
	at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:452)
	at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
	at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
	at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)

ivy引用的相關jar是(除IBM提供的):

<dependency org="javax.resource" name="connector" rev="1.0"	conf="runtime->default" />
		<dependency org="javax.jms" name="jms" rev="1.1" conf="runtime->default"/>	
		<dependency org="org.springframework" name="org.springframework.jms" rev="3.0.5.RELEASE"	conf="runtime->default" />

項目中原引用的org.springframework相關JAR爲3.2.5.RELEASE:

<dependency org="org.springframework" name="spring-context-support" rev="3.2.5.RELEASE"	conf="runtime->default" />

把springframework引用的JMS版本改下  :

<dependency org="org.springframework" name="spring-jms" rev="3.2.5.RELEASE"	conf="runtime->default" />

呵呵,折騰了我不少時間,排除問題,主要是本地項目裏面沒有3.2.5的,而且name也不一樣,也就沒有多加註意 


再tomcat啓動的時候由於版本衝突問題,也會出現:

嚴重: StandardWrapper.Throwable  
java.lang.NoSuchMethodError: org/springframework/core/convert/converter/ConverterRegistry.addConverter(Ljava/lang/Class;Ljava/lang/Class;Lorg/springframework/core/convert/converter/Converter;)V  
    at org.springframework.core.convert.support.DefaultConversionService.addScalarConverters(DefaultConversionService.java:64)  
    at org.springframework.core.convert.support.DefaultConversionService.addDefaultConverters(DefaultConversionService.java:54)  
    at org.springframework.core.convert.support.DefaultConversionService.<init>(DefaultConversionService.java:43)  
    at org.springframework.core.env.AbstractPropertyResolver.<init>(AbstractPropertyResolver.java:41)  
    at org.springframework.core.env.PropertySourcesPropertyResolver.<init>(PropertySourcesPropertyResolver.java:41)  
    at org.springframework.core.env.AbstractEnvironment.<init>(AbstractEnvironment.java:98)  
    at org.springframework.core.env.StandardEnvironment.<init>(StandardEnvironment.java:54)  
    at org.springframework.web.context.support.StandardServletEnvironment.<init>(StandardServletEnvironment.java:44)  
    at org.springframework.web.servlet.HttpServletBean.createEnvironment(HttpServletBean.java:213)  
    at org.springframework.web.servlet.HttpServletBean.getEnvironment(HttpServletBean.java:203)  
    at org.springframework.web.servlet.HttpServletBean.init(HttpServletBean.java:126)  
    at javax.servlet.GenericServlet.init(GenericServlet.java:212)  
    at org.apache.catalina.core.StandardWrapper.loadServlet(StandardWrapper.java:1173)  
    at org.apache.catalina.core.StandardWrapper.load(StandardWrapper.java:993)  
    at org.apache.catalina.core.StandardContext.loadOnStartup(StandardContext.java:4350)  
    at org.apache.catalina.core.StandardContext.start(StandardContext.java:4659)  
    at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:791)  
    at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:771)  
    at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:546)  
    at org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java:1041)  
    at org.apache.catalina.startup.HostConfig.deployDirectories(HostConfig.java:964)  
    at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:502)  
    at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1277)  
    at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:321)  
    at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:119)  
    at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1053)  
    at org.apache.catalina.core.StandardHost.start(StandardHost.java:785)  
    at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)  
    at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:445)  
    at org.apache.catalina.core.StandardService.start(StandardService.java:519)  
    at org.apache.catalina.core.StandardServer.start(StandardServer.java:710)  
    at org.apache.catalina.startup.Catalina.start(Catalina.java:581)  
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)  
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:79)  
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)  
    at java.lang.reflect.Method.invoke(Method.java:618)  
    at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:289)  
    at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:414)



發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章