Introduction into SOAP, setting up a simple webservice with PHP SOAP
I was asked to create a simple webservice that would allow us to transfer a intranet post to an external CMS. In this post I will explain the steps you must take to set-up a simple webservice with the PHP SOAP extension.
The first step, create a simple class that we will use to request data from
We will create a class with one method that returns a string with the parameter we called it. The method will accept one parameter and will check if the value is correct.
Nothing special here, notice that we don’t throw a normal exception but return the SoapFault instead so we can handle the error clientside.
The second step, create a WSDL document
The WSDL document is a simple XML document that describes:
– the service itself
– the operations of the service
– the data types used in the service
The WSDL will describe our method getItem from our Blog service class so we can call it later on.
So how does this WSDL thing look like?
<?xml version="1.0" encoding="UTF-8" ?>
<definitions name="Entities"
targetNamespace="urn:blog"
xmlns:typens="urn:blog"
xmlns:xsd="http://www.w3.org/2001/XMLSchema"
xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/"
xmlns:soapenc="http://schemas.xmlsoap.org/soap/encoding/"
xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/"
xmlns="http://schemas.xmlsoap.org/wsdl/">
<types>
<xsd:schema xmlns="http://www.w3.org/2001/XMLSchema" targetNamespace="urn:blog">
</xsd:schema>
</types>
<message name="getItemResponse">
<part name="string" type="xsd:string" />
</message>
<message name="getItemRequest">
<part name="return" type="xsd:string" />
</message>
<portType name="blogPortType">
<operation name="getItem">
<documentation>Returns a simple test string</documentation>
<input message="typens:getItemRequest" />
<output message="typens:getItemResponse" />
</operation>
</portType>
<binding name="blogBinding" type="typens:blogPortType">
<soap:binding style="rpc" transport="http://schemas.xmlsoap.org/soap/http"/>
<operation name="getItem">
<soap:operation soapAction="urn:blog#getItem" style="rpc" />
<input>
<soap:body use="encoded" namespace="urn:blog" encodingStyle="http://schemas.xmlsoap.org/soap/encoding/" />
</input>
<output>
<soap:body use="encoded" namespace="urn:blog" encodingStyle="http://schemas.xmlsoap.org/soap/encoding/" />
</output>
</operation>
</binding>
<service name="blog">
<port name="blogPort" binding="typens:blogBinding">
<soap:address location="http://{siteUrl}/webservice/server.php" />
</port>
</service>
</definitions>
As you can see the WSDL consists of different parts:
– the namespace
– the types
– messages
– ports (the porttype contains the set of operations, each operation has its own input and output messages)
– bindings (tells how to transport the requests, it describes the protocol used, just like the ports it contains the set of operations used)
– service (defines the ports that are supported by the service, its a collection of ports)
The third step, map our Blog service class to the webserver
After we have created our WSDL we can start building our server. In just a few lines we have a SOAP server up and running.
// Init the server
$oServer = new SoapServer('blog.wsdl');
// Register the blog service class and all the methods
$oServer->setClass('BlogService');
// Rock 'n roll
$oServer->handle();
The fourth and final step, test our webservice
Its a good idea to test the webservice with a program like soapUI, it often can provide some additional information when troubleshooting. (They have a free version available on their website).
To test our webservice in PHP we can use the following code:
ini_set("soap.wsdl_cache_enabled", "0"); // Disable the wsdl cache
$oClient = new SoapClient(
// Url to our wsdl, http://{siteUrl}/webservice/index.php?wsdl is also possible
'{siteUrl}/webservice/blog.wsdl',
array(
'trace' => true,
'exceptions'=> true
));
try {
$aResult = $oClient->getItem(4);
var_dump($aResult);
} catch (SoapFault $e) {
exit($e->faultstring);
}
You should see a SOAP fault, because the id number 4 we gave to the getItem function didn’t exist in our Blog service class. Change the value to 1,2,3 or 5 and you should get a nice response back.
Another pretty neat function is $oClient->__getFunctions(); it will return all the function that are available in the webservice.
This was just a short introduction to SOAP, a lot more is possible with SOAP.
Special thanks to David Zuelke for the nice SOAP introduction at the PHPbenelux conference 2010.
Example files:
Webservice.rar
Just deploy the example files on your webserver, change the {siteUrl} values in the files with your domain and call the client.php
Thanks, really helpful! I was struggling for 3 days to get it right. Now I’ve got the correct setup!
Ben
27 Oct 11 at 2:27 pm
Hi,
Thanks to share this information. How can we create different class for different functionality of web service?
jayendra
11 Nov 11 at 2:14 pm
online canadian pharmacy no prescription enclomiphene
cheapest buy enclomiphene new zealand buy online
purchase enclomiphene generic uk buy
17 Aug 25 at 9:13 am
kamagra en ligne sans ordonnance
kamagra expédié contre remboursement le samedi
livraison de nuit en ligne kamagra
17 Aug 25 at 9:22 am
buy androxal cheap online canada
cheapest buy androxal generic in united states
buy cheap androxal canada how to buy
17 Aug 25 at 12:08 pm
Online pharmacies no perscription flexeril cyclobenzaprine
online order flexeril cyclobenzaprine cheap alternatives
how to buy flexeril cyclobenzaprine generic online mastercard
17 Aug 25 at 1:15 pm
how to order dutasteride lowest price
get dutasteride generic europe
how to buy dutasteride buy germany
17 Aug 25 at 2:05 pm
get gabapentin purchase line
buying gabapentin generic online uk
gabapentin without a presciption canadian perscriptions gabapentin
17 Aug 25 at 2:47 pm
is there anything over the counter like fildena
fildena shipped overnight no perscription
cheap fildena uk meds
17 Aug 25 at 5:45 pm
cheap itraconazole cheap info
cheap itraconazole generic extended release
how to order itraconazole generic is it safe
18 Aug 25 at 3:27 am
order staxyn buy germany
buy staxyn generic drug india
cheapest buy staxyn australia buy online
18 Aug 25 at 5:00 am
how to order avodart generic does it work
cheapest buy avodart usa sales
Where to buy generic avodart online without a perscription
18 Aug 25 at 5:05 am
buy rifaximin for sale usa
pfizer rifaximin canada
buy cheap rifaximin price generic
18 Aug 25 at 7:06 am
canadian drug store xifaxan
purchase xifaxan generic tablets
how to buy xifaxan purchase england
18 Aug 25 at 7:30 am
generic kamagra canada žádný předpis
generique kamagra
comprar kamagra en arg
18 Aug 25 at 9:59 am
Hello! I’m giving away a cash reward. To get yours, contact me on Telegram at @moneymake29_bot.
Greetings! Your monetary compensation is ready. Please add me on Telegram @moneymake29_bot to receive it.
29 Aug 25 at 2:28 am