Create a JAX-WS Web service application that uses Web Services Addressing
Web Services Addressing (WS-Addressing) aids interoperability between Web services by defining a standard way to address Web services and provide addressing information in messages. This task describes the steps that are required to create a JAX-WS Web service that is accessed using a WS-Addressing endpoint reference. The task also describes the extra steps that are required to use stateful resources as part of the Web service.
The steps that are described in this task apply to servers and clients that run on WAS.
Perform this task if we are creating a JAX-WS Web service that uses the WS-Addressing specification. This task uses the JAX-WS 2.1 WS-Addressing APIs to create the required endpoint reference. Alternatively, we can create endpoint references using the IBM proprietary WS-Addressing API, and convert them into JAX-WS 2.1 API objects for use with the rest of the application.
- Provide a Web service interface that returns an endpoint reference to the target service.
The interface must return an endpoint reference, which it can do by using a factory operation or a separate factory service. The target service can front a resource instance, for example a shopping cart.
- Implement the Web service created in the previous step. For the WS-Addressing portion of the implementation...
- Include annotations to specify WS-Addressing behavior. See Web Services Addressing annotations for more details.
- If the interface involves a Web service that fronts a resource instance, create or look up the resource instance.
- For a resource instance, obtain the identifier of the resource. The resource identifier is application dependent and might be generated during the creation of the resource instance.
Do not put sensitive information in the resource identifier, because the identifier is propagated in the SOAP message.
- Create an endpoint reference that references the Web service by following the instructions in Create endpoint references using the JAX-WS 2.1 Web Services Addressing API. For a resource instance, pass in the resource identifier as a parameter.
- Return the endpoint reference.
- If the Web service uses resource instances, extend the implementation to match incoming messages to the appropriate resource instances. Because you associated the resource identifier with the endpoint reference that you created earlier, any incoming messages targeted at that endpoint reference contain the resource identifier information as a reference parameter in the SOAP header of the message. Because the resource identifier is passed in the SOAP header, you do not have to expose it on the Web service interface. When WAS receives the message, it puts this information into the message context on the thread. Extend the implementation to perform the following actions:
- Obtain the resource instance identifier from the message context.
- If using the 2005/08 WS-Addressing namespace, use the REFERENCE_PARAMETERS property of the MessageContext class.
- If using the 2004/08 WS-Addressing namespace, use the WS-Addressing API, specifically the EndpointReferenceManager.getReferenceParameterFrom MessageContext(QName resource_id) method.
Use the following method for the 2005/08 namespace:
... List resourceIDList = (List)getContext().getMessageContext().get(MessageContext.REFERENCE_PARAMETERS); ...Use the following method for the 2004/08 namespace:...String resource_identifier = EndpointReferenceManager.getReferenceParameterFromMessageContext(PRINTER_ID_PARAM_QNAME); ...
- Forward the message to the appropriate resource instance.
- Set a proxy client to communicate with the service.
- Use the wsimport or xjc tool to generate the artifacts required by the client.
To use the 2004/08 WS-Addressing specification, specify the provided binding file, APP_ROOT/util/SubmissionEndpointReference.xjb, as the -b parameter of the tool. This parameter tells the tool to generate endpoint reference objects using the SubmissionEndpointReference class that is part of the IBM implementation of the standard JAX-WS 2.1 API. If we do not specify this bindings file, the resulting endpoint reference objects will not work with the standard JAX-WS 2.1 API.
- In the client code, create an instance of the service class.
- Obtain a proxy object from the service class. There are several ways to use the JAX-WS 2.1 API to obtain proxy objects. For example, there are several getPort methods on the Service class and one on the EndpointReference class.
See, refer to the API documentation.
- Use the Addressing or SubmissionAddressing feature to enable WS-Addressing support. For example, create a proxy using a getPort method that accepts Web service features as a parameter. If we prefer, we can enable WS-Addressing support using another method, such as policy sets.
See see Enable Web Services Addressing support for JAX-WS applications.
- Use the proxy object to invoke the service method that returns the endpoint reference.
The following sample code shows a client invoking a Web service to add two numbers together. The Web service issues a ticket (the resource identifier) to the client, and requires the client to use this ticket when invoking the Web service. The client creates two proxies. The first proxy obtains the ticket as an endpoint reference from the service. The second proxy uses the AddressingFeature class to enable WS-Addressing for the 2005/08 specification, and invokes the service to add the two numbers together.
... CalculatorService service = new CalculatorService(); // Create the first proxy Calculator port1 = service.getCalculatorServicePort(); // Obtain the ticket as an endpoint reference from the service W3CEndpointReference epr = port1.getTicket(); // Create the second proxy, using an addressing feature to enable WS-Addressing Calculator port2 = epr.getPort(Calculator.class, new AddressingFeature()); // Invoke the service to add the numbers int answer = port2.add(value0, value1); System.out.println("The answer is: " + answer); ...If the metadata of the endpoint reference conflicts with the information already associated with the outbound message, for example if the proxy object is configured to represent a different interface, a javax.xml.ws.WebServiceException exception is thrown on attempts to invoke the endpoint.
To set message-addressing properties, such as a reply to endpoint, use the IBM proprietary WS-Addressing SPI and the BindingProvider class
- Set a Dispatch client to communicate with the service. Configure a client in different ways; the following steps describe one example.
- Create an instance of the service.
- Add a port to the service object.
- Create an instance of the Dispatch class, passing in the endpoint reference.
- Create a Dispatch<T> object. Use the Service.createDispatch method with the following parameters:
- The endpoint reference returned by the service, which represents the resource to forward messages to.
- An array of Web service features. Include one or more WS-Addressing features to enable WS-Addressing. See Enable Web Services Addressing support for JAX-WS applications for more details.
There are several variations of the Service.createDispatch method; see the API documentation for more details.
- Compose the client request message.
- Invoke the service endpoint with the Dispatch client.
The following code shows an example fragment of a Dispatch client that enables 2004/08 WS-Addressing.
... CalculatorService service = new CalculatorService(); Dispatch(<SOAPMessage> dispatch = service.createDispatch( endpointReference, SOAPMessage.class, Service.Mode.MESSAGE, new SubmissionAddressingFeature(true) ); ...
Results
The Web service and client are configured to use endpoint references through the WS-Addressing support. For a detailed example that includes code, see Example: Creating a Web service that uses the JAX-WS 2.1 Web Services Addressing API to access a generic Web service resource instance.
Next steps
- Refer to Web Services Addressing security considerations for information about security with WS-Addressing.
- Deploy the application. If we used WS-Addressing annotations or features in the code, you do not have to take any additional steps to enable WS-Addressing support.
See and for other scenarios that might require additional steps, for example enabling WS-Addressing support using policy sets, see Enable Web Services Addressing support for JAX-WS applications.
Create endpoint references using the JAX-WS 2.1 Web Services Addressing API 
Related concepts
JAX-WS client model
Related tasks
Enable Web Services Addressing support for JAX-WS applications
Specifying and acquiring message-addressing properties using the IBM proprietary Web Services Addressing SPIs
Implement Web services applications with JAX-WS
Generating Java artifacts for JAX-WS applications from a WSDL file
Generating Java artifacts for JAX-WS applications
Use the Web Services Addressing APIs: Creating an application that uses endpoint references
Related
Web Services Addressing APIs
IBM proprietary Web Services Addressing SPIs
wsgen command for JAX-WS applications
wsimport command for JAX-WS applications
Example: Creating a Web service that uses the JAX-WS 2.1 Web Services Addressing API to access a generic Web service resource instance 
Related information
JAX-WS API: http://jcp.org/aboutJava/communityprocess/mrel/jsr224/index2.html
developerWorks article: JAX-WS client APIs in the Web Services Feature Pack for WAS V6.1, Part 1: Creating a Dispatch client
developerWorks article: JAX-WS client APIs in the Web Services Feature Pack for WAS V6.1, Part 2: Creating a proxy client