Introduction au Zend Framework

 Apprendre Zend Framework

appendix

 Guide de référence Zend Framework


  •  Zend_Gdata
  •  Zend_Http
  •  Zend_InfoCard
  •  Zend_Json
  •  Zend_Layout
  •  Zend_Ldap
  •  Zend_Loader
  •  Zend_Locale
  •  Zend_Log
  •  Zend_Mail
  •  Zend_Markup
  •  Zend_Measure
  •  Zend_Memory
  •  Zend_Mime
  •  Zend_Navigation
  •  Zend_Oauth
  •  Zend_OpenId
  •  Zend_Paginator
  •  Zend_Pdf
  •  Zend_ProgressBar
  •  Zend_Queue
  •  Zend_Reflection
  •  Zend_Registry
  •  Zend_Rest

  •  Zend_Search_Lucene
  •  Zend_Serializer
  •  Zend_Server
  •  Zend_Service
  •  Zend_Session
  •  Zend_Soap
  •  Zend_Tag
  •  Zend_Test
  •  Zend_Text
  •  Zend_TimeSync
  •  Zend_Tool
  •  Zend_Tool_Framework
  •  Zend_Tool_Project
  •  Zend_Translate
  •  Zend_Uri
  •  Zend_Validate
  •  Zend_Version
  •  Zend_View
  •  Zend_Wildfire
  •  Zend_XmlRpc
  • ZendX_Console_Process_Unix
  • ZendX_JQuery
  • Translation 61.2% Update 2010-11-28 - Revision 23149 - Version ZF 1.11.x

    65.2. 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.

    65.2.1. 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 :

      // Accepte une response compressée
      $client = new Zend_Soap_Client("some.wsdl",
        array(
      'compression' => SOAP_COMPRESSION_ACCEPT));
      ...
      // Compresse les requêtes avec gzip et un taux de 5
      $client = new Zend_Soap_Client("some.wsdl",
        array(
      'compression' =>
                  
      SOAP_COMPRESSION_ACCEPT SOAP_COMPRESSION_GZIP 5));
      ...
      // Compresse les requêtes en utilisant deflate
      $client = new Zend_Soap_Client("some.wsdl",
        array(
      'compression' =>
                  
      SOAP_COMPRESSION_ACCEPT SOAP_COMPRESSION_DEFLATE));

    65.2.2. 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 :

    ...
    //****************************************************************
    //                Code du serveur
    //****************************************************************
    // class MyClass {
    //     /**
    //      * Cette méthode utilise ...
    //      *
    //      * @param integer $inputParam
    //      * @return string
    //      */
    //     public function method1($inputParam) {
    //         ...
    //     }
    //
    //     /**
    //      * Cette méthode utilise ...
    //      *
    //      * @param integer $inputParam1
    //      * @param string  $inputParam2
    //      * @return float
    //      */
    //     public function method2($inputParam1, $inputParam2) {
    //         ...
    //     }
    //
    //     ...
    // }
    // ...
    // $server = new Zend_Soap_Server(null, $options);
    // $server->setClass('MyClass');
    // ...
    // $server->handle();
    //
    //****************************************************************
    //                Fin du code du serveur
    //****************************************************************

    $client = new Zend_Soap_Client("MyService.wsdl");
    ...
    // $result1 est une chaine
    $result1 $client->method1(10);
    ...
    // $result2 est un flottant
    $result2 $client->method2(22'some string');
    digg delicious meneame google twitter technorati facebook

    Comments

    Loading...