SOAP Example

Added June 2013

SOAP requests may be formed by combining an XML-format document (based on the requirements for the web service as defined in the WSDL for the service) with a set of HTTP binding headers. The technique is essentially the same as described in Customizing POST headers, except that the Content-Type may be different and typically you will be adding a SOAPAction header. The following is a an example of a real web service (as of June 2013) provided by WebserviceX.NET which returns details about airports based on the airport code. The format of the XML request document is as follows:

<?xml version="1.0" encoding="utf-8"?>

<soap:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">

  <soap:Body>

    <getAirportInformationByAirportCode xmlns="http://www.webserviceX.NET">

       <airportCode>$AIRPORTCODE$</airportCode>

    </getAirportInformationByAirportCode>

  </soap:Body>

</soap:Envelope>

 

To generate an actual request, we copy the above into a file, replacing the $AIRPORTCODE$ with the actual code (see CGIUTL for one technique to simply such replacements). In order to specify the desired Content-Type and the SOAPAction header, we insert it at the top of our file, followed by a blank line and then the XML request:

Content-Type: text/xml; charset=utf-8

SOAPAction: "http://www.webserviceX.NET/getAirportInformationByAirportCode"

 

<xml doc here>

 

Assuming that our generated request file is called "airport.req", we can then call the web service as follows:

flags = XHTTPF_REQPOST                               ! POST request (typical for SOAP)

flags = flags or XHTTPF_FILEREQ or XHTTPF_FILERESP   ! request and response are both filespecs

flags = flags or XHTTPF_HDRBODY                      ! request body contains header lines

url = "http://www.webserviceX.NET/airport.asmx"

xcall HTTP, 1, status, flags, url, "airport.req", "airport.rsp"

 

To examine the final headers as sent to the service, add the XHTTPF_DEBUG flag and then check the resulting DEBUG.REQ file, which should look something like:

POST /airport.asmx HTTP/1.1

Host: www.webservicex.net

Content-Type: text/xml; charset="utf-8"

SOAPAction: "http://www.webserviceX.NET/getAirportInformationByAirportCode"

Content-Length: 418

 

<?xml version="1.0" encoding="utf-8"?>

<soap:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema"

               xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">

  <soap:Body>

    <getAirportInformationByAirportCode xmlns="http://www.webserviceX.NET">

      <airportCode>LAX</airportCode>

    </getAirportInformationByAirportCode>

  </soap:Body>

</soap:Envelope>

 

Note that the POST, Host:, and Content-Length headers are added automatically, but the Content-Type and SOAPAction headers are copied from the request file.

The complete program demonstrating this service, airport.bp, can be found in the EXLIB.