Zend_Soap

Zend_Soap_Server

La classe Zend_Soap_Server a été créée pour simplifier la création d'un service Web SOAP en PHP.

Elle peut être utilisée en mode WSDL ou non-WSDL, et elle utilise des fonctions ou des classes pour définir le service Web rendu.

Lorsque le composant Zend_Soap_Server fonctionne en mode WSDL, il utilise le document WSDL pour décrire le comportement des objets du serveur ainsi que les options de transport vers les clients.

Un document WSDL peut être auto-généré en utilisant le composant Zend_Soap_AutoDiscovery, ou alors construit manuellement avec la classe Zend_Soap_Wsdl ou tout autre outil de génération de XML

Si le mode non-WSDL est utilisé, alors toutes les options du protocole doivent être configurées.

Constructeur de Zend_Soap_Server

Le constructeur de Zend_Soap_Server s'utilise différemment selon que l'on fonctionne en mode WSDL ou non.

Constructeur de Zend_Soap_Server en mode WSDL

Le constructeur de Zend_Soap_Server prend 2 paramètres optionnel en mode WSDL:

  1. $wsdl, l'URI permettant l'accès au fichier WSDL [1] setWsdl($wsdl) .

  2. $options - options de création des objets serveurs [2] setOptions($options) .

    Les options suivantes sont reconnues en mode WSDL :

    • "soap_version" ("soapVersion") : version du protocole SOAP à utiliser (SOAP_1_1 ou SOAP_1_2).

    • "actor" : l'URI du serveur SOAP.

    • "classmap" ("classMap") : utilisé pour faire correspondre des types WSDL à des classes PHP.

      L'option doit être un tableau avec pour clés les types WSDL et pour valeur les classes PHP correspondantes.

    • "encoding" : encodage interne des caractères (l'encodage externe est toujours UTF-8).

    • "wsdl" : équivalent à un appel à setWsdl($wsdlValue)

Constructeur de Zend_Soap_Server en mode non-WSDL

Le premier paramètre du constructeur doit être mis à la valeur NULL si vous voulez utiliser Zend_Soap_Server en mode non-WSDL.

Vous devez aussi spécifier "uri" dans ce cas (voir juste après).

Le second paramètre de constructeur est un tableau ($options) d'options permettant la création de l'objet serveur SOAP.[3] setOptions($options) .

Les options suivantes sont reconnues en mode non-WSDL :

  • "soap_version" ("soapVersion") : version SOAP à utiliser (SOAP_1_1 ou SOAP_1_2).

  • "actor" : l'URI du serveur SOAP.

  • "classmap" ("classMap") : utilisé pour faire correspondre des types WSDL à des classes PHP.

    L'option doit être un tableau avec pour clés les types WSDL et pour valeur les classes PHP correspondantes.

  • "encoding" : encodage interne des caractères (l'encodage externe est toujours UTF-8).

  • "wsdl" : équivalent à un appel à setWsdl($wsdlValue).

Méthodes de définitions de l'API du service

Il existe 2 manières de déclarer l'API de votre serveur SOAP.

La première consiste à attacher des classes à l'objet Zend_Soap_Server, celles-ci devront alors décrire l'API du service en totalité :

  1. ...
  2. class MyClass {
  3.     /**
  4.      * Cette méthode accepte ...
  5.      *
  6.      * @param integer $inputParam
  7.      * @return string
  8.      */
  9.     public function method1($inputParam) {
  10.         ...
  11.     }
  12.  
  13.     /**
  14.      * Cette méthode accepte ...
  15.      *
  16.      * @param integer $inputParam1
  17.      * @param string  $inputParam2
  18.      * @return float
  19.      */
  20.     public function method2($inputParam1, $inputParam2) {
  21.         ...
  22.     }
  23.  
  24.     ...
  25. }
  26. ...
  27. $server = new Zend_Soap_Server(null, $options);
  28. // Connecte la classe au serveur Soap
  29. $server->setClass('MyClass');
  30. // Connecte un objet déjà initialisé au serveur Soap
  31. $server->setObject(new MyClass());
  32. ...
  33. $server->handle();

Note: Important!
Vous devriez complètement décrire chaque méthode grâce aux blocs de commentaires PHPDoc dans le cas où vous souhaitez utiliser l'auto découverte du service pour préparer le WSDL correspondant.

La seconde manière de décrire l'API de votre service Web est d'utiliser des fonctions PHP conjointement avec les méthodes addFunction() ou loadFunctions() :

  1. ...
  2. /**
  3. * Cette fonction ...
  4. *
  5. * @param integer $inputParam
  6. * @return string
  7. */
  8. function function1($inputParam) {
  9.     ...
  10. }
  11.  
  12. /**
  13. * Cette fonction ...
  14. *
  15. * @param integer $inputParam1
  16. * @param string  $inputParam2
  17. * @return float
  18. */
  19. function function2($inputParam1, $inputParam2) {
  20.     ...
  21. }
  22. ...
  23. $server = new Zend_Soap_Server(null, $options);
  24. $server->addFunction('function1');
  25. $server->addFunction('function2');
  26. ...
  27. $server->handle();

Gestion des objets de requête et de réponse

Note: Avancée
Cette section décrit la gestion avancée des requêtes et réponses SOAP et pourra être évitée.

Le composant Zend_Soap_Server effectue des requêtes et récupère des réponses, ceci automatiquement. Il est possible d'intercepter la requête/réponse pour ajouter du pré ou post processus.

Requête

La méthode Zend_Soap_Server::handle() utilise la requête depuis le flux d'entrée standard ('php://input'). Le comportement peut être changé en passant des paramètres à la méthode handle() ou en spécifiant sa propre requête grâce à la méthode setRequest() :

...
$server = new Zend_Soap_Server(...);
...
// Affecte une requête personnalisée
$server->handle($request);
...
// Affecte une requête personnalisée
$server->setRequest();
$server->handle();

Un objet de requête peut être représenté de plusieurs manières différentes :

  • DOMDocument (casté en XML)

  • DOMNode (le DOMDocument attaché est extrait et casté en XML)

  • SimpleXMLElement (casté en XML)

  • stdClass (__toString() est appelée et son contenu est vérifié comme XML valide)

  • chaînes de caractères (vérifiée comme XML valide)

La dernière requête utilisée et traitée peut être récupérée en utilisant la méthode getLastRequest() :

  1. ...
  2. $server = new Zend_Soap_Server(...);
  3. ...
  4. $server->handle();
  5. $request = $server->getLastRequest();

Réponse

Zend_Soap_Server::handle() émet automatiquement la réponse vers le flux standard de sortie. Ce comportement peut être changé en utilisant setReturnResponse() avec une valeur TRUE ou FALSE en paramètre. [4] setReturnResponse() . La réponse générée par handle() est alors retournée et non plus émise.

  1. ...
  2. $server = new Zend_Soap_Server(...);
  3. ...
  4. // Récupère la réponse plutôt que de l'émettre
  5. $server->setReturnResponse(true);
  6. ...
  7. $response = $server->handle();
  8. ...

Autrement, la dernière réponse peut être récupérer avec la méthode getLastResponse() :

  1. ...
  2. $server = new Zend_Soap_Server(...);
  3. ...
  4. $server->handle();
  5. $response = $server->getLastResponse();
  6. ...

[1] Peut être spécifié plus tard avec la méthode
[2] Peut être spécifié plus tard avec la méthode
[3] Les options se configurent aussi plus tard, grâce à la méthode
[4] L'état actuel du drapeau de retour de la réponse peut être vérifié via la méthode sans paramètre.

Zend_Soap