Network Deployment (Distributed operating systems), v8.0 > Develop and deploying applications > Develop web services > Develop JAX-WS clients


Develop a JAX-WS client from a WSDL file

Java API for XML-Based Web Services (JAX-WS) tooling supports generating Java artifacts you need to develop static JAX-WS web services clients when starting with a WSDL file. When you use a top-down development approach to developing JAX-WS web services by starting with a WSDL file, obtain the Uniform Resource Locator (URL) for the WSDL file.

(Windows) If the WSDL file is a local file, the URL looks like this example: file:drive:\path\file_name.wsdl.

(AIX) (Solaris) If the WSDL file is a local file, the URL looks like this example: file:/path/file_name.wsdl.

You can also specify local files using the absolute or relative file system path.

The static client programming model for JAX-WS is the called the dynamic proxy client. The dynamic proxy client invokes a web service based on a service endpoint interface provided. After creation of the proxy, the client application can invoke methods on the proxy just like a standard implementation of those interfaces. For JAX-WS web service clients using the dynamic proxy programming model, use the JAX-WS tool, wsimport, to process a WSDL file and generate portable Java artifacts that are used to create a web service client. Create the following portable Java artifacts using the wsimport tool:

The wsimport, wsgen, schemagen and xjc command-line tools are not supported on the z/OS platform. This functionality is provided by the assembly tools provided with WAS running on the z/OS platform. Read about these command-line tools for JAX-WS applications to learn more about these tools.

WAS provides Java API for XML-Based Web Services (JAX-WS) and Java Architecture for XML Binding (JAXB) tooling. The wsimport, wsgen, schemagen and xjc command-line tools are located in...

WAS_HOME\bin\
Similar tooling is provided by the Java SE Development Kit (JDK) 6. On some occasions, the artifacts generated by both the tooling provided by WAS and the JDK support the same levels of the specifications. In general, the artifacts generated by the JDK tools are portable across other compliant runtime environments. However, it is a best practice to use the tools provided with this product to achieve seamless integration within the WAS environment and to take advantage of the features that may be only supported in WAS.

To take advantage of JAX-WS and JAXB V2.2 tooling, use the tools provided with the application server that are located in the WAS_HOME\bin\ directory.

In addition to using the tools from the command-line, you can invoke these JAX-WS tools from within the Ant build environments. Use the com.sun.tools.ws.ant.WsImport Ant task from within the Ant build environment to invoke the wsimport tool.

To function properly, this Ant task requires that you invoke Ant using the ws_ant script.


Procedure

Run the wsimport command to generate the portable client artifacts. The wsimport tool is located in the WAS_HOME\bin\ directory.

(Windows)

WAS_HOME\bin\wsimport.bat wsdl_URL
(AIX) (Solaris)
WAS_HOME/bin/wsimport.sh wsdl_URL

(Optional) Use the following options with the wsimport command:

Read about the wsimport command to learn more about this command and additional options that you can specify.


Results

You have the generated Java artifacts to create a JAX-WS client that can invoke JAX-WS web services.

To learn more about the usage, syntax, and parameters for the wsimport command, see the wsimport command for JAX-WS applications documentation.


Example

The following example illustrates how the wsimport command is used to process the sample ping.wsdl file to generate portable artifacts.

  1. Copy the following ping.wsdl file to a temporary directory.
    <?xml version="1.0" encoding="UTF-8"?>
    <!--
     * This program can be used, run, copied, modified and distributed
      *  without royalty for the purpose of developing, using, marketing, or distributing.
     -->
    <wsdl:definitions xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/"
     xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/"
     xmlns:tns="http://com/ibm/was/wssample/sei/ping/"
     xmlns:xsd="http://www.w3.org/2001/XMLSchema" name="PingService"
     targetNamespace="http://com/ibm/was/wssample/sei/ping/">
    <wsdl:types>
    <xsd:schema
       targetNamespace="http://com/ibm/was/wssample/sei/ping/"
       xmlns:xsd="http://www.w3.org/2001/XMLSchema">
    
    
    <xsd:element name="pingStringInput">
    <xsd:complexType>
    <xsd:sequence>
    <xsd:element name="pingInput" type="xsd:string" />
    </xsd:sequence>
    </xsd:complexType>
    </xsd:element>
    </xsd:schema>
    </wsdl:types>
    <wsdl:message name="pingOperationRequest">
    <wsdl:part element="tns:pingStringInput" name="parameter" />
    </wsdl:message>
    <wsdl:portType name="PingServicePortType">
    <wsdl:operation name="pingOperation">
    <wsdl:input message="tns:pingOperationRequest" />
    
    </wsdl:operation>
    </wsdl:portType>
    <wsdl:binding name="PingSOAP" type="tns:PingServicePortType">
    <soap:binding style="document"
       transport="http://schemas.xmlsoap.org/soap///publib.boulder.ibm.com/infocenter/wasinfo/v8r0/index.jsp?topic=/  " />
    <wsdl:operation name="pingOperation">
    <soap:operation soapAction="pingOperation" style="document" />
    <wsdl:input>
    <soap:body use="literal" />
    </wsdl:input>
    </wsdl:operation>
    </wsdl:binding>
    <wsdl:service name="PingService">
    <wsdl:port binding="tns:PingSOAP" name="PingServicePort">
    <soap:address
        location="http://localhost:9080/WSSampleSei/PingService" />
    </wsdl:port>
    </wsdl:service>
    </wsdl:definitions>
    
  2. Run the wsimport command from the WAS_HOME\bin\ directory.

    (Windows)

    WAS_HOME\bin\wsimport.bat -keep -verbose ping.wsdl
    

    (AIX) (Solaris) Operating systems such as AIX or Linux source the script to the parent shell to inherit the exported variables by running the following command:

    . ./setupCmdLine.sh  (Notice the space between the periods.)
    
    from the . / WAS_HOME>/bin directory. Run the following wsimport command:
    WAS_HOME/bin/wsimport.sh -keep -verbose ping.wsdl
    

After generating the template files from the wsimport command, the following files are generated:

com\ibm\was\wssample\sei\ping\ObjectFactory.java
com\ibm\was\wssample\sei\ping\package-info.java
com\ibm\was\wssample\sei\ping\PingServicePortType.java
com\ibm\was\wssample\sei\ping\PingService.java
com\ibm\was\wssample\sei\ping\PingStringInput.java

The ObjectFactory.java, PingService.java, and PingServicePortType.java files are the generated Java class files to use when you package the Java artifacts with your client implementation inside a JAR or a web application archive (WAR) file.


What to do next

Complete the client implementation.
JAX-WS
JAX-WS client programming model
Assembly tools
Implement static JAX-WS web services clients
Invoke JAX-WS web services asynchronously
Develop a dynamic client using JAX-WS APIs
Generate Java artifacts for JAX-WS applications from a WSDL file


Related


wsimport command for JAX-WS applications
Web services specifications and APIs
Java API for XML Web Services (JAX-WS) API documentation
Java API for XML Web Services (JAX-WS) API User's Guide documentation

+

Search Tips   |   Advanced Search