Zend_Soap_Server

Zend_Soap_Client

Zend_Soap_Client est une classe destinée à simplifier l'interrogation de services SOAP.

Cette classe peut être utilisée en mode WSDL ou non WSDL.

Lorsque Zend_Soap_Client fonctionne en mode WSDL, il utilise le document WSDL pour définir les options de la couche de transport des données.

Le fichier WSDL est en général fournit par le service auquel vous souhaitez accéder. Si la description WSDL n'est pas disponible, vous pouvez vouloir utiliser Zend_Soap_Client en mode non WSDL . Dans ce cas, toutes les options du protocole devront être définies explicitement dans la classe Zend_Soap_Client.

Constructeur de Zend_Soap_Client

Le constructeur de Zend_Soap_Client accepte 2 paramètres:

  • $wsdl : l'URI du fichier WSDL.

  • $options : options de création.

Ces deux paramètres peuvent être insérés après construction, ceci grâce aux méthodes setWsdl($wsdl) et setOptions($options).

Note: Important!
Si vous utilisez Zend_Soap_Client en mode non WSDL, vous devez fournir les options 'location' et 'uri'.

Les options suivantes sont reconnues:

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

  • 'classmap' ('classMap') : doit être utilisé pour faire correspondre des types WSDL à des classes PHP.

    Cette option doit être un tableau avec comme clés les types WSDL et comme valeurs les noms des classes PHP.

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

  • 'wsdl' : qui est équivalent à un appel à setWsdl($wsdlValue).

    Changer cette option peut faire basculer Zend_Soap_Client en mode WSDL ou non WSDL.

  • 'uri' : cible du service SOAP (requis pour le mode non WSDL, inusité en mode WSDL).

  • 'location' : l'URL à requêter (requis pour le mode non WSDL, inusité en mode WSDL).

  • 'style' : style de requête (inusité en mode WSDL): SOAP_RPC ou SOAP_DOCUMENT.

  • 'use' : méthode d'encodage des messages (inusité en mode WSDL): SOAP_ENCODED ou SOAP_LITERAL.

  • 'login' et 'password' : login et password pour l'authentification HTTP.

  • 'proxy_host', 'proxy_port', 'proxy_login', et 'proxy_password' : utilisés pour une connexion HTTP via un proxy.

  • 'local_cert' et 'passphrase' : options d'authentification HTTPS.

  • 'compression' : options de compression ; c'est une combinaison entre SOAP_COMPRESSION_ACCEPT, SOAP_COMPRESSION_GZIP et SOAP_COMPRESSION_DEFLATE, qui peuvent être utilisées de cette manière :

    1. // Accepte une response compressée
    2. $client = new Zend_Soap_Client("some.wsdl",
    3.   array('compression' => SOAP_COMPRESSION_ACCEPT));
    4. ...
    5. // Compresse les requêtes avec gzip et un taux de 5
    6. $client = new Zend_Soap_Client("some.wsdl",
    7.   array('compression' =>
    8.             SOAP_COMPRESSION_ACCEPT | SOAP_COMPRESSION_GZIP | 5));
    9. ...
    10. // Compresse les requêtes en utilisant deflate
    11. $client = new Zend_Soap_Client("some.wsdl",
    12.   array('compression' =>
    13.             SOAP_COMPRESSION_ACCEPT | SOAP_COMPRESSION_DEFLATE));

Effectuer des requêtes SOAP

Lorsqu'un objet Zend_Soap_Client est crée, nous sommes prêts à créer des requêtes SOAP.

Chaque méthode du service Web est liée à une méthode virtuelle de l'objet Zend_Soap_Client, qui s'utilise de manière tout à fait classique comme PHP le définit.

Voici un exemple :

  1. ...
  2. //****************************************************************
  3. //                Code du serveur
  4. //****************************************************************
  5. // class MyClass {
  6. //     /**
  7. //      * Cette méthode utilise ...
  8. //      *
  9. //      * @param integer $inputParam
  10. //      * @return string
  11. //      */
  12. //     public function method1($inputParam) {
  13. //         ...
  14. //     }
  15. //
  16. //     /**
  17. //      * Cette méthode utilise ...
  18. //      *
  19. //      * @param integer $inputParam1
  20. //      * @param string  $inputParam2
  21. //      * @return float
  22. //      */
  23. //     public function method2($inputParam1, $inputParam2) {
  24. //         ...
  25. //     }
  26. //
  27. //     ...
  28. // }
  29. // ...
  30. // $server = new Zend_Soap_Server(null, $options);
  31. // $server->setClass('MyClass');
  32. // ...
  33. // $server->handle();
  34. //
  35. //****************************************************************
  36. //                Fin du code du serveur
  37. //****************************************************************
  38.  
  39. $client = new Zend_Soap_Client("MyService.wsdl");
  40. ...
  41. // $result1 est une chaine
  42. $result1 = $client->method1(10);
  43. ...
  44. // $result2 est un flottant
  45. $result2 = $client->method2(22, 'some string');


Zend_Soap_Server