Understanding WSDL
A developer can develop a web service completely by just having a WSDL provided.
Join the DZone community and get the full member experience.
Join For FreeQuick Tip: WSDL file should be read from bottom to top
As the name indicates, this single file contains all the information needed to understand a web service, like URL, Req and Response message structure, operations that can be performed on this web service, etc.
In simpler terms, a developer can develop a web service completely by just having a WSDL provided. We also share this WSDL to those who are consuming this web service so they know how to interact.
A few points to note before we look at a WSDL file:
XML message structure can be defined inside a WSDL itself
We can have an XSD (XSD is XML itself. Its purpose is to define the structure of Req and Response message) as a separate file and import into a WSDL
Predominantly used for SOAP web services
data:image/s3,"s3://crabby-images/b64c1/b64c17bb76d7ab6712279514afdf39c1b0407e18" alt=""
Now let’s dive into WSDL file, note that a WSDL file should be read from bottom to top (I learned from experience) as from element “Service > binding > PortType > operation > input(req) / Output (resp) > Message > types (fields) details of input and output“.
1. Let's start with the most bottom element: “Service”. The service element shows the service name and where it can be accessed from — in other words, its endpoint
2. The binding
element defines exactly how each operation
will take place over the network. In this case, we are using SOAP.
data:image/s3,"s3://crabby-images/00e8d/00e8df9dd8a01902882714023634e9f18aac9d79" alt=""
3. A WSDL portType
is used to combine multiple message
s (e.g. input, output) into a single operation. Here, we define three synchronous (input/output) operations
and the message
s that must be used for each.
data:image/s3,"s3://crabby-images/96d73/96d73d2941d8fc37b91fc8c774d701dc1a104c47" alt=""
4. message
element is used to define a message exchanged between a web service, consisting of zero or more part
s.
data:image/s3,"s3://crabby-images/cfa2d/cfa2dc600dfa85b46330c87921b47584807d79bf" alt=""
5.The types
element defines the data types (XML elements) that are used by the web service.
data:image/s3,"s3://crabby-images/5aaa9/5aaa9682821a90a7d2dd5a7c1b73348659c828b4" alt=""
Info for beginners in IBM Integration bus: By default, a WSDL file is mandatory if you are using SOAP input-node/Req Node, but if you don’t want to validate input req or receive generic input from multiple front-ends/send to multiple backends on the same flow, you can use SOAP nodes without WSDL by changing “Operation mode” to Gateway mode.
A SOAP webservice can be implemented in IIB with both SOAP and HTTP nodes.
Opinions expressed by DZone contributors are their own.
Comments