WSDL Reading, a Beginner's Guide
This article explains how to read a WSDL document by analyzing the Web Services description of a public sample Service. During the article a tree diagram is developed from the content of the WSDL document. The tree illustrates the structure of WSDL. The reader will get an understanding of the WSDL elements and their relationships.
The root element of a WSDL document is definitions. So we start the WSDL tree with a definitions node as root. See figure 1:
Figure1:
<wsdl:service name="BLZService"> <wsdl:port name="BLZServiceSOAP11port_http" binding="tns:BLZServiceSOAP11Binding"> <soap:address location="http://www.thomas-bayer.com:80/axis2/services/BLZService"/> </wsdl:port> <wsdl:port name="BLZServiceSOAP12port_http" binding="tns:BLZServiceSOAP12Binding"> <soap12:address location="http://www.thomas-bayer.com:80/axis2/services/BLZService"/> </wsdl:port> <wsdl:port name="BLZServiceHttpport" binding="tns:BLZServiceHttpBinding"> <http:address location="http://www.thomas-bayer.com:80/axis2/services/BLZService"/> </wsdl:port> </wsdl:service>
The name of the service is BLZService. A service can have multiple ports marked in figure 2 with a * character. Each port describes a way to access the service. In our BLZService example there are three ports. One for SOAP 1.1, one for SOAP 1.2 and one for the HTTP binding.
data:image/s3,"s3://crabby-images/dde9e/dde9eef7aba99256c594c741ee222dbcb71f1f50" alt="Ports of a Service Ports of a Service"
Figure2:
Let's have a look at the first port in listing 2.
<wsdl:port name="BLZServiceSOAP11port_http" binding="tns:BLZServiceSOAP11Binding"> <soap:address location="http://www.thomas-bayer.com:80/axis2/services/BLZService"/> </wsdl:port>
It's child element address has a different XML prefix than the other elements. The prefix soap is bound to the SOAP 1.1 binding in this document. Instead of the SOAP binding other bindings for JMS or a file transport can be used. The address element has one attribute named location pointing to an endpoint address of the service.
data:image/s3,"s3://crabby-images/dc7f8/dc7f83b47cd47bcfe9378f42834c3a38cfcf2974" alt="Endpoint Address Endpoint Address"
Figure3:
To move on, we have to look at the binding attribute of the port.
The value "tns:BLZServiceSOAP11Binding" points to a binding further up in the document. Each port is pointing to a different binding in this example. As a consequence the BLZService WSDL has three bindings.
data:image/s3,"s3://crabby-images/df48a/df48a73fc4a975df84c12f9d50b6c6c0a853a3a5" alt="A Port references a Binding A Port references a Binding"
Figure4:
A binding provides details about a specific transport. The binding in figure 5 has two different types of children.
data:image/s3,"s3://crabby-images/90d44/90d441ce264b7d5de79f2afadf34a824b9c45947" alt="SOAP Binding SOAP Binding"
Figure5:
First we have a look at the soap:binding element in listing 3. The value of the transport attribute is an URI that indicates that SOAP messages should be send over HTTP. The value "document" of the style attribute gives us a clue about the message style together with the use attribute of the soap:body elements. In our example we have a Document/Literal message style.
A binding can specify different transport options for each method of a service.
<wsdl:binding name="BLZServiceSOAP11Binding" type="tns:BLZServicePortType"> <soap:binding transport="http://schemas.xmlsoap.org/soap/http" style="document"/> <wsdl:operation name="getBank"> <soap:operation soapAction="" style="document"/> <wsdl:input> <soap:body use="literal"/> </wsdl:input> <wsdl:output> <soap:body use="literal"/> </wsdl:output> </wsdl:operation> </wsdl:binding>
Let's have a look at listing 4. There you can find transport options for the getBank operation.
Inside the wsdl:operation element there is a soap:operation element at line 2 defining details for the SOAP protocol and its transport. The soapAction is a reminiscent from the past. The Basic Profile of the Web Services Interoperability Organization stipulates that the soapAction should be used with a fixed value of an empty string.
<wsdl:operation name="getBank"> <soap:operation soapAction="" style="document"/> <wsdl:input> <soap:body use="literal"/> </wsdl:input> <wsdl:output> <soap:body use="literal"/> </wsdl:output> </wsdl:operation>
Because Web Services set the focus on messages not parameters, information about the transport of these messages can be found in the wsdl:input and wsdl:output element. A service may specify one or several faults as an alternative for the output.
data:image/s3,"s3://crabby-images/f5f2f/f5f2f73dfee46069ba4171ba9bf65f2812ad75ae" alt="Binding Operation Binding Operation"
Figure6:
The soap:body and soap:header elements can describe a message further. In the example the style is always literal.
data:image/s3,"s3://crabby-images/85043/85043cb3f109dd91f2c385f945d28525b6c0d537" alt="soap:body Elements soap:body Elements"
Figure7:
It is time again to move up in the WSDL. Now we follow the value of the type attribute of the binding. It points to a portType with the same name further up in the document.
data:image/s3,"s3://crabby-images/33fd6/33fd6ff20fc065f27cb4ddccb1251a3be814d0d1" alt="Binding referencing a PortType Binding referencing a PortType"
Figure8:
Now we have crossed the border from the concrete details about the transport and location of a service to its pure abstract description of its interface. PortType is in WSDL 1.1 similar to the interface of the Web Service. In WSDL 2.0 the term portType is substituted with the term interface.
An interface can have several operations. An operation corresponds to a function in procedural programming.
The WSDL of the BLZService has only one portType. All of the three bindings refer to the one portType named BLZServicePortType.
data:image/s3,"s3://crabby-images/38650/386506bdca39737c5eef3f588429d78e98c6373f" alt="Operations of a portType Operations of a portType"
Figure9:
Inside a portType we find operation elements as in the binding. But this time the input and output describe the structure of the messages not transport specific options.
data:image/s3,"s3://crabby-images/93395/93395b55f0834862240b0a7f46fcb6bd65644013" alt="Input and Output of an Operation Input and Output of an Operation"
Figure10:
The message attribute of the input refers again up in the WSDL document. It refers to a message named tns:getBank. Further up in the document we find a corresponding message with this name.
<wsdl:portType name="BLZServicePortType"> <wsdl:operation name="getBank"> <wsdl:input message="tns:getBank"/> <wsdl:output message="tns:getBankResponse" wsaw:Action="http://thomas-bayer.com/blz/BLZService/getBankResponse"/> </wsdl:operation> </wsdl:portType>
data:image/s3,"s3://crabby-images/2d1af/2d1af2a353fcfa2782cef9efc35277a47094246c" alt="Message Message"
Figure11:
The message getBank has one part element as child. A WSDL specialist will recognize the value of the attribute name, "parameters" indicates the wrapper substyle of the document/literal style.
<wsdl:message name="getBank"> <wsdl:part name="parameters" element="tns:getBank"/> </wsdl:message>
The attribute element at line 2 points again further up. It refers to an element named tns:getBank. We will find this element in a XML Schema.
data:image/s3,"s3://crabby-images/4c5c8/4c5c801ea9400004ca61fe39b158c61da4e42766" alt="A Message and its parts A Message and its parts"
Figure12:
The next child of the definitions element is types.
data:image/s3,"s3://crabby-images/50a3a/50a3aaddd72f0a8fef46ec6658251473807bb1d5" alt="The Types Section The Types Section"
Figure13:
The types element can have multiple XML schemas as children.
data:image/s3,"s3://crabby-images/06157/06157c7f05907f37e5160e1854e715f58e0de7c5" alt="Schemas used in a WSDL Schemas used in a WSDL"
Figure14:
Listing 7 shows the types element and an embedded schema.
<wsdl:types> <xsd:schema attributeFormDefault="unqualified" elementFormDefault="qualified" targetNamespace="http://thomas-bayer.com/blz/"> <xsd:element name="getBank" type="tns:getBankType"/> <xsd:element name="getBankResponse" type="tns:getBankResponseType"/> <xsd:complexType name="getBankType"> <xsd:sequence> <xsd:element name="blz" type="xsd:string"/> </xsd:sequence> </xsd:complexType> <xsd:complexType name="getBankResponseType"> <xsd:sequence> <xsd:element name="details" type="tns:detailsType"/> </xsd:sequence> </xsd:complexType> <xsd:complexType name="detailsType"> <xsd:sequence> <xsd:element minOccurs="0" name="bezeichnung" type="xsd:string"/> <xsd:element minOccurs="0" name="bic" type="xsd:string"/> <xsd:element minOccurs="0" name="ort" type="xsd:string"/> <xsd:element minOccurs="0" name="plz" type="xsd:string"/> </xsd:sequence> </xsd:complexType> </xsd:schema> </wsdl:types>
In a schema we can find the definition of:
- complexTypes
- simpleTypes
- elements
In document/literal style all the parts point to elements.
data:image/s3,"s3://crabby-images/d81d9/d81d997c55620dbb6e19a990772555c149c57456" alt="A Part can reference an Element A part can reference an Element"
Figure15:
Listing 8 shows the declaration of the getBank element.
<xsd:element name="getBank" type="tns:getBankType"/>
The type of this element is a complexType named getBankType definded somewhere else in the schema.
data:image/s3,"s3://crabby-images/103c4/103c4738de06a2a6562645297d511bf8178707f5" alt="An Element references its Type An Element references its Type"
Figure16:
The getBankType has a sequence as modulgroup containing one element named blz of the build-in schema type string.
data:image/s3,"s3://crabby-images/f6de8/f6de8f1ccef160447d204691138ec6d3f26be884" alt="A ComplexType with a Sequence as Content A ComplexType with a Sequence as Content"
Figure17:
Listing 9 shows the definition of the getBankType.
<xsd:complexType name="getBankType"> <xsd:sequence> <xsd:element name="blz" type="xsd:string"/> </xsd:sequence> </xsd:complexType>
A sequence can consist of several elements that describe the order of elements in a SOAP message.
data:image/s3,"s3://crabby-images/5d724/5d72436bc0d57c74e4eadfa9c60f920644769b30" alt="The entire Structure of a WSDL Document The entire Structure of a WSDL Document"
Figure18:
Finally we are through the entire WSDL description of the sample service.
All WSDL documents have the same structure as the BLZService. To understand a WSDL start reading at the bottom and work your way up by following the right attributes as shown in this article.
I hope this article was helpful to learn how to read a WSDL document.
Thomas Bayer
bayer@predic8.com