Fuse 6 is no longer supported
As of February 2025, Red Hat Fuse 6 is no longer supported. If you are using Fuse 6, please upgrade to Red Hat build of Apache Camel.此内容没有您所选择的语言版本。
Chapter 17. Using SOAP over JMS
Overview
复制链接链接已复制到粘贴板!
				The SOAP over JMS protocol is defined by the World Wide Web Consortium(W3C) as a way of providing a more reliable transport layer to the customary SOAP/HTTP protocol used by most services. The Apache CXF implementation is fully compliant with the specification and should be compatible with any framework that is also compliant.
			
				This transport uses JNDI to find the JMS destinations. When an operation is invoked, the request is packaged as a SOAP message and sent in the body of a JMS message to the specified destination.
			
				Publishing and consuming SOAP/JMS services differ from SOAP/HTTP services in the following ways:
			
- SOAP/JMS service addressed are specified using a special JMS URI
- you must use the Apache CXF specific factory objects to use SOAP/JMS endpoints
JMS URIs
复制链接链接已复制到粘贴板!
				JMS endpoints use a JMS URI as defined in the URI Scheme for JMS 1.0. Example 17.1, “JMS URI syntax” shows the syntax for a JMS URI.
			
Example 17.1. JMS URI syntax
jms:variant:destination?options
jms:variant:destination?options
				Table 17.1, “JMS URI variants” describes the available variants for the JMS URI.
			
| Variant | Description | 
|---|---|
| jndi | Specifies that the destination is a JNDI name for the target destination. When using this variant, you must provide the configuration for accessing the JNDI provider. | 
| topic | Specifies that the destination is the name of the topic to be used as the target destination. The string provided is passed into Session.createTopic()to create a representation of the destination. | 
| queue | Specifies that the destination is the name of the queue to be used as the target destination. The string provided is passed into Session.createQueue()to create a representation of the destination. | 
				Table 17.2, “JMS properties settable as URI options” shows the URI options.
			
| Property | Default | Description | 
|---|---|---|
| deliveryMode | PERSISTENT | Specifies whether to use JMS PERSISTENTorNON_PERSISTENTmessage semantics. In the case ofPERSISTENTdelivery mode, the JMS broker stores messages in persistent storage before acknowledging them; whereasNON_PERSISTENTmessages are kept in memory only. | 
| replyToName | 
								Explicitly specifies the reply destination to appear in the  JMSReplyToheader. Setting this property is recommended for applications that have request-reply semantics because the JMS provider will assign a temporary reply queue if one is not explicitly set.
								The value of this property has an interpretation that depends on the variant specified in the JMS URI:
							 
 | |
| priority | 4 | Specifies the JMS message priority, which ranges from 0 (lowest) to 9 (highest). | 
| timeToLive | 0 | Time (in milliseconds) after which the message will be discarded by the JMS provider. 0represents an infinite lifetime. | 
| jndiConnectionFactoryName | Specifies the JNDI name of the JMS connection factory. | |
| jndiInitialContextFactory | Specifies the fully qualified Java class name of the JNDI provider (which must be of javax.jms.InitialContextFactorytype). Equivalent to setting thejava.naming.factory.initialJava system property. | |
| jndiURL | Specifies the URL that initializes the JNDI provider. Equivalent to setting the java.naming.provider.urlJava system property. | 
Publishing a service
复制链接链接已复制到粘贴板!
				The JAX-WS standard 
publish() method cannot be used to publish a SOAP/JMS service. Instead, you must use the Apache CXF's JaxWsServerFactoryBean class as shown in Example 17.2, “Publishing a SOAP/JMS service”.
			Example 17.2. Publishing a SOAP/JMS service
				The code in Example 17.2, “Publishing a SOAP/JMS service” does the following:
			
Consuming a service
复制链接链接已复制到粘贴板!
				The standard JAX-WS APIs cannot be used to consume a SOAP/JMS service. Instead, you must use the Apache CXF's 
JaxWsProxyFactoryBean class as shown in Example 17.3, “Consuming a SOAP/JMS service”.
			Example 17.3. Consuming a SOAP/JMS service
				The code in Example 17.3, “Consuming a SOAP/JMS service” does the following: