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.Questo contenuto non è disponibile nella lingua selezionata.
Chapter 3. Defining Logical Messages Used by a Service
Abstract
						A service is defined by the messages exchanged when its operations are invoked. In a WSDL contract these messages are defined using 
message element. The messages are made up of one or more parts that are defined using part elements.
					Overview
Copia collegamentoCollegamento copiato negli appunti!
				A service’s operations are defined by specifying the logical messages that are exchanged when an operation is invoked. These logical messages define the data that is passed over a network as an XML document. They contain all of the parameters that are a part of a method invocation.
			
				Logical messages are defined using the 
message element in your contracts. Each logical message consists of one or more parts, defined in part elements.
			Tip
				While your messages can list each parameter as a separate part, the recommended practice is to use only a single part that encapsulates the data needed for the operation.
			
Messages and parameter lists
Copia collegamentoCollegamento copiato negli appunti!
				Each operation exposed by a service can have only one input message and one output message. The input message defines all of the information the service receives when the operation is invoked. The output message defines all of the data that the service returns when the operation is completed. Fault messages define the data that the service returns when an error occurs.
			
				In addition, each operation can have any number of fault messages. The fault messages define the data that is returned when the service encounters an error. These messages usually have only one part that provides enough information for the consumer to understand the error.
			
Message design for integrating with legacy systems
Copia collegamentoCollegamento copiato negli appunti!
				If you are defining an existing application as a service, you must ensure that each parameter used by the method implementing the operation is represented in a message. You must also ensure that the return value is included in the operation’s output message.
			
				One approach to defining your messages is RPC style. When using RPC style, you define the messages using one part for each parameter in the method’s parameter list. Each message part is based on a type defined in the 
types element of the contract. Your input message contains one part for each input parameter in the method. Your output message contains one part for each output parameter, plus a part to represent the return value, if needed. If a parameter is both an input and an output parameter, it is listed as a part for both the input message and the output message.
			
				RPC style message definition is useful when service enabling legacy systems that use transports such as Tibco or CORBA. These systems are designed around procedures and methods. As such, they are easiest to model using messages that resemble the parameter lists for the operation being invoked. RPC style also makes a cleaner mapping between the service and the application it is exposing.
			
Message design for SOAP services
Copia collegamentoCollegamento copiato negli appunti!
				While RPC style is useful for modeling existing systems, the service’s community strongly favors the wrapped document style. In wrapped document style, each message has a single part. The message’s part references a wrapper element defined in the 
types element of the contract. The wrapper element has the following characteristics:
			- It is a complex type containing a sequence of elements. For more information see Section 2.5, “Defining complex data types”.
- If it is a wrapper for an input message:- It has one element for each of the method’s input parameters.
- Its name is the same as the name of the operation with which it is associated.
 
- If it is a wrapper for an output message:- It has one element for each of the method’s output parameters and one element for each of the method’s inout parameters.
- Its first element represents the method’s return parameter.
- Its name would be generated by appendingResponseto the name of the operation with which the wrapper is associated.
 
Message naming
Copia collegamentoCollegamento copiato negli appunti!
				Each message in a contract must have a unique name within its namespace. It is recommended that you use the following naming conventions:
			
- Messages should only be used by a single operation.
- Input message names are formed by appendingRequestto the name of the operation.
- Output message names are formed by appendingResponseto the name of the operation.
- Fault message names should represent the reason for the fault.
Message parts
Copia collegamentoCollegamento copiato negli appunti!
				Message parts are the formal data units of the logical message. Each part is defined using a 
part element, and is identified by a name attribute and either a type attribute or an element attribute that specifies its data type. The data type attributes are listed in Table 3.1, “Part data type attributes”.
			
				Messages are allowed to reuse part names. For instance, if a method has a parameter, 
foo, that is passed by reference or is an in/out, it can be a part in both the request message and the response message, as shown in Example 3.1, “Reused part”.
			Example 3.1. Reused part
Example
Copia collegamentoCollegamento copiato negli appunti!
				For example, imagine you had a server that stored personal information and provided a method that returned an employee’s data based on the employee's ID number. The method signature for looking up the data is similar to Example 3.2, “personalInfo lookup method”.
			
Example 3.2. personalInfo lookup method
personalInfo lookup(long empId)
personalInfo lookup(long empId)
				This method signature can be mapped to the RPC style WSDL fragment shown in Example 3.3, “RPC WSDL message definitions”.
			
Example 3.3. RPC WSDL message definitions
				It can also be mapped to the wrapped document style WSDL fragment shown in Example 3.4, “Wrapped document WSDL message definitions”.
			
Example 3.4. Wrapped document WSDL message definitions