spring的配置文件
<
bean
id
="destination"
class
="org.springframework.jndi.JndiObjectFactoryBean"
>
<
property
name
="jndiTemplate"
>
<
ref
bean
="jndiTemplate"
/>
</
property
>
<
property
name
="jndiName"
>
<
value
>
SendJMSQueue
</
value
>
<!--
<value>queue/SendJMSTopic</value>
-->
</
property
>
</
bean
>
在jboss中一定要在queue的jndiName属性值的前面添加queue/,否则会抛出如下异常
org.springframework.beans.factory.BeanCreationException: Error creating bean with name
'
jmsTemplate
'
defined in
class
path resource [com
/
company
/
project
/
monitor
/
monitorContext.xml]: Cannot resolve reference to bean
'
destination
'
while
setting bean property
'
defaultDestination
'
; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name
'
destination
'
defined in
class
path resource [com
/
company
/
project
/
monitor
/
monitorContext.xml]: Initialization of bean failed; nested exception is javax.naming.NameNotFoundException: SendJMSQueue not bound
org.springframework.beans.factory.BeanCreationException: Error creating bean with name
'
destination
'
defined in
class
path resource [com
/
company
/
project
/
monitor
/
monitorContext.xml]: Initialization of bean failed; nested exception is javax.naming.NameNotFoundException: SendJMSQueue not bound
javax.naming.NameNotFoundException: SendJMSQueue not bound
at org.jnp.server.NamingServer.getBinding(NamingServer.java:
529
)
at org.jnp.server.NamingServer.getBinding(NamingServer.java:
537
)
at org.jnp.server.NamingServer.getObject(NamingServer.java:
543
)
at org.jnp.server.NamingServer.lookup(NamingServer.java:
296
)
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:
585
)
at sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:
294
)
at sun.rmi.transport.Transport$
1
.run(Transport.java:
153
)
at java.security.AccessController.doPrivileged(Native Method)
at sun.rmi.transport.Transport.serviceCall(Transport.java:
149
)
at sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:
460
)
at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:
701
)
at java.lang.Thread.run(Thread.java:
595
)
at sun.rmi.transport.StreamRemoteCall.exceptionReceivedFromServer(StreamRemoteCall.java:
247
)
at sun.rmi.transport.StreamRemoteCall.executeCall(StreamRemoteCall.java:
223
)
at sun.rmi.server.UnicastRef.invoke(UnicastRef.java:
126
)
at org.jnp.server.NamingServer_Stub.lookup(Unknown Source)
at org.jnp.interfaces.NamingContext.lookup(NamingContext.java:
625
)
at org.jnp.interfaces.NamingContext.lookup(NamingContext.java:
587
)
at javax.naming.InitialContext.lookup(InitialContext.java:
351
)
at org.springframework.jndi.JndiTemplate$
1
.doInContext(JndiTemplate.java:
124
)
at org.springframework.jndi.JndiTemplate.execute(JndiTemplate.java:
86
)
at org.springframework.jndi.JndiTemplate.lookup(JndiTemplate.java:
122
)
at org.springframework.jndi.JndiTemplate.lookup(JndiTemplate.java:
147
)
at org.springframework.jndi.JndiLocatorSupport.lookup(JndiLocatorSupport.java:
86
)
at org.springframework.jndi.JndiObjectLocator.lookup(JndiObjectLocator.java:
104
)
at org.springframework.jndi.JndiObjectFactoryBean.lookupWithFallback(JndiObjectFactoryBean.java:
164
)
at org.springframework.jndi.JndiObjectFactoryBean.afterPropertiesSet(JndiObjectFactoryBean.java:
151
)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:
1091
)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:
396
)
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:
233
)
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:
145
)
at org.springframework.beans.factory.support.BeanDefinitionValueResolver.resolveReference(BeanDefinitionValueResolver.java:
186
)
at org.springframework.beans.factory.support.BeanDefinitionValueResolver.resolveValueIfNecessary(BeanDefinitionValueResolver.java:
106
)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.applyPropertyValues(AbstractAutowireCapableBeanFactory.java:
1046
)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:
857
)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:
378
)
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:
233
)
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:
145
)
at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:
283
)
at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:
313
)
at org.springframework.context.support.ClassPathXmlApplicationContext.
<
init
>
(ClassPathXmlApplicationContext.java:
87
)
at org.springframework.context.support.ClassPathXmlApplicationContext.
<
init
>
(ClassPathXmlApplicationContext.java:
72
)
at org.springframework.context.support.ClassPathXmlApplicationContext.
<
init
>
(ClassPathXmlApplicationContext.java:
63
)
......
但是在weblogic中却不能添加这个前缀,否则会抛出如下异常
org.springframework.beans.factory.BeanCreationException: Error creating bean with name
'
jmsTemplate
'
defined
in
class
path resource [com
/
company
/
project
/
monitor
/
monitorContext.xml]: Cannot resolve reference to bean
'
destination
'
while
setting bean property
'
defaultDestination
'
; nested exception
is
org.springframework.beans.factory.BeanCreationException: Error creating bean with name
'
destination
'
defined
in
class
path resource [com
/
company
/
project
/
monitor
/
monitorContext.xml]: Initialization of bean failed; nested exception
is
javax.naming.NameNotFoundException: While trying to lookup
'
queue.SendJMSQueue
'
didn
'
t find subcontext
'
queue
'
. Resolved
''
[Root exception is javax.naming.NameNotFoundException: While trying to lookup
'
queue.SendJMSQueue
'
didn
'
t find subcontext
'
queue
'
. Resolved
''
]; remaining name
'
queue/SendJMSQueue
'
org.springframework.beans.factory.BeanCreationException: Error creating bean with name
'
destination
'
defined
in
class
path resource [com
/
company
/
project
/
monitor
/
monitorContext.xml]: Initialization of bean failed; nested exception
is
javax.naming.NameNotFoundException: While trying to lookup
'
queue.SendJMSQueue
'
didn
'
t find subcontext
'
queue
'
. Resolved
''
[Root exception is javax.naming.NameNotFoundException: While trying to lookup
'
queue.SendJMSQueue
'
didn
'
t find subcontext
'
queue
'
. Resolved
''
]; remaining name
'
queue/SendJMSQueue
'
javax.naming.NameNotFoundException: While trying to lookup
'
queue.SendJMSQueue
'
didn
'
t find subcontext
'
queue
'
. Resolved
''
[Root exception is javax.naming.NameNotFoundException: While trying to lookup
'
queue.SendJMSQueue
'
didn
'
t find subcontext
'
queue
'
. Resolved
''
]; remaining name
'
queue/SendJMSQueue
'
at weblogic.rjvm.ResponseImpl.unmarshalReturn(ResponseImpl.java:
191
)
at weblogic.rmi.cluster.ClusterableRemoteRef.invoke(ClusterableRemoteRef.java:
315
)
at weblogic.rmi.cluster.ClusterableRemoteRef.invoke(ClusterableRemoteRef.java:
250
)
at weblogic.jndi.
internal
.ServerNamingNode_910_WLStub.lookup(Unknown Source)
at weblogic.jndi.
internal
.WLContextImpl.lookup(WLContextImpl.java:
374
)
at weblogic.jndi.
internal
.WLContextImpl.lookup(WLContextImpl.java:
362
)
at javax.naming.InitialContext.lookup(InitialContext.java:
351
)
at org.springframework.jndi.JndiTemplate$
1
.doInContext(JndiTemplate.java:
124
)
at org.springframework.jndi.JndiTemplate.execute(JndiTemplate.java:
86
)
at org.springframework.jndi.JndiTemplate.lookup(JndiTemplate.java:
122
)
at org.springframework.jndi.JndiTemplate.lookup(JndiTemplate.java:
147
)
at org.springframework.jndi.JndiLocatorSupport.lookup(JndiLocatorSupport.java:
86
)
at org.springframework.jndi.JndiObjectLocator.lookup(JndiObjectLocator.java:
104
)
at org.springframework.jndi.JndiObjectFactoryBean.lookupWithFallback(JndiObjectFactoryBean.java:
164
)
at org.springframework.jndi.JndiObjectFactoryBean.afterPropertiesSet(JndiObjectFactoryBean.java:
151
)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:
1091
)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:
396
)
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:
233
)
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:
145
)
at org.springframework.beans.factory.support.BeanDefinitionValueResolver.resolveReference(BeanDefinitionValueResolver.java:
186
)
at org.springframework.beans.factory.support.BeanDefinitionValueResolver.resolveValueIfNecessary(BeanDefinitionValueResolver.java:
106
)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.applyPropertyValues(AbstractAutowireCapableBeanFactory.java:
1046
)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:
857
)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:
378
)
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:
233
)
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:
145
)
at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:
283
)
at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:
313
)
at org.springframework.context.support.ClassPathXmlApplicationContext.
<
init
>
(ClassPathXmlApplicationContext.java:
87
)
at org.springframework.context.support.ClassPathXmlApplicationContext.
<
init
>
(ClassPathXmlApplicationContext.java:
72
)
at org.springframework.context.support.ClassPathXmlApplicationContext.
<
init
>
(ClassPathXmlApplicationContext.java:
63
)
......
Caused by: javax.naming.NameNotFoundException: While trying to lookup
'
queue.SendJMSQueue
'
didn
'
t find subcontext
'
queue
'
. Resolved
''
at weblogic.jndi.
internal
.BasicNamingNode.newNameNotFoundException(BasicNamingNode.java:
1123
)
at weblogic.jndi.
internal
.BasicNamingNode.lookupHere(BasicNamingNode.java:
245
)
at weblogic.jndi.
internal
.ServerNamingNode.lookupHere(ServerNamingNode.java:
171
)
at weblogic.jndi.
internal
.BasicNamingNode.lookup(BasicNamingNode.java:
204
)
at weblogic.jndi.
internal
.RootNamingNode_WLSkel.invoke(Unknown Source)
at weblogic.rmi.
internal
.BasicServerRef.invoke(BasicServerRef.java:
517
)
at weblogic.rmi.cluster.ClusterableServerRef.invoke(ClusterableServerRef.java:
224
)
at weblogic.rmi.
internal
.BasicServerRef$
1
.run(BasicServerRef.java:
407
)
at weblogic.security.acl.
internal
.AuthenticatedSubject.doAs(AuthenticatedSubject.java:
363
)
at weblogic.security.service.SecurityManager.runAs(SecurityManager.java:
147
)
at weblogic.rmi.
internal
.BasicServerRef.handleRequest(BasicServerRef.java:
403
)
at weblogic.rmi.
internal
.BasicServerRef.access$
300
(BasicServerRef.java:
56
)
at weblogic.rmi.
internal
.BasicServerRef$BasicExecuteRequest.run(BasicServerRef.java:
934
)
at weblogic.work.ExecuteThread.execute(ExecuteThread.java:
207
)
at weblogic.work.ExecuteThread.run(ExecuteThread.java:
179
)


















































































































