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:
            
 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",
 
            SOAP_COMPRESSION_ACCEPT | SOAP_COMPRESSION_GZIP | 5));
 
...
 
// Compresse les requêtes en utilisant deflate
 
$client = new Zend_Soap_Client("some.wsdl",
 
            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 : 
...
 
//****************************************************************
 
//                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');