我写了一个在Weblogic 10.3上运行的Spring应用程序。在这个应用程序中,我有一些JMS队列使用者。
有时我在应用程序关闭或打开时遇到错误(我在两种情况下都看到了这个错误)说:
java.lang.NoClassDefFoundError: org/springframework/jms/connection/SmartConnectionFactory
at org.springframework.jms.connection.ConnectionFactoryUtils.releaseConnection(ConnectionFactoryUtils.java:72)
at org.springframework.jms.listener.AbstractJmsListeningContainer.refreshSharedConnection(AbstractJmsListeningContainer.java:385)at org.springframework.jms.listener.DefaultMessageListenerContainer.refreshConnectionUntilSuccessful(DefaultMessageListenerContainer.java:779)
at org.springframework.jms.listener.DefaultMessageListenerContainer.recoverAfterListenerSetupFailure(DefaultMessageListenerContainer.java:761)
at org.springframework.jms.listener.DefaultMessageListenerContainer$AsyncMessageListenerInvoker.run(DefaultMessageListenerContainer.java:892)
at java.lang.Thread.run(Thread.java:619)
Caused by: java.lang.ClassNotFoundException: org.springframework.jms.connection.SmartConnectionFactory
at weblogic.utils.classloaders.GenericClassLoader.findLocalClass(GenericClassLoader.java:283)
at weblogic.utils.classloaders.GenericClassLoader.findClass(GenericClassLoader.java:256)
at weblogic.utils.classloaders.ChangeAwareClassLoader.findClass(ChangeAwareClassLoader.java:54)
at java.lang.ClassLoader.loadClass(ClassLoader.java:303)
at java.lang.ClassLoader.loadClass(ClassLoader.java:248)
at weblogic.utils.classloaders.GenericClassLoader.loadClass(GenericClassLoader.java:176)
at weblogic.utils.classloaders.ChangeAwareClassLoader.loadClass(ChangeAwareClassLoader.java:35)
at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:316)
... 6 more
为什么我会收到此错误,我应该怎么做才能解决? spring.jar的版本是2.5.5
答案 0 :(得分:2)
该异常意味着该类未加载到JVM中。确保spring.jar位于Weblogic服务器的类路径或库文件夹中。
答案 1 :(得分:0)
你在战争中拥有这个课程非常好,但在Weblogic中,战争有自己的类加载器。由于您的堆栈跟踪显示了一个JMS监听器,我会问:监听器在哪里?如果它在战争中,那你就有了一个谜。但它确实看起来好像它在其他地方,并且正是在其他地方错过了这个Spring类。