Maison >développement back-end >tutoriel php >Explication détaillée du savon php implémentant le service d'interface de service Web

Explication détaillée du savon php implémentant le service d'interface de service Web

藏色散人
藏色散人avant
2020-01-16 17:52:583545parcourir

Qu'est-ce que le service Web ? Je n'entrerai pas dans les détails. Vous pouvez vous référer à la description de l'encyclopédie Encyclopédie du service Web Baidu .

Soap est un protocole et une spécification technique utilisés dans la mise en œuvre de services Web.

Il existe deux façons d'implémenter l'interface du service Web, l'une est la manière qui nécessite de générer un document wsdl, l'autre est la manière qui n'a pas besoin de générer un document wsdl.

Avant l'opération réelle, vérifiez d'abord si votre environnement prend en charge Soap, puis modifiez le fichier de configuration php.ini et définissez l'élément "soap.wsdl_cache_enabled" sur 0.

Pas besoin de générer un document wsdl

Cette méthode est plus simple que la méthode qui doit générer un document wsdl, mais certaines méthodes ne sont pas prises en charge, comme Get the __getFunctions () de la méthode de fonctionnement. Cela dépend de votre choix.

côté serveur ts1.php

<?php
class testA{
        public function sayHi($str){
                return &#39;hi,&#39;.$str;
        }
        public function add($a,$b){
                return $a+$b;
        }
}
$ss = new SoapServer(null, array(&#39;uri&#39;=>&#39;sampleA&#39;));
$ss->setClass(&#39;testA&#39;);
$ss->handle();

Dans le fichier ts1.php côté serveur, créez une classe, puis créez SoapServer et effectuez les réglages, l'uri est utilisé pour assurer la cohérence sexe.

côté client tc1.php

<?php
$client = new SoapClient(null, array(
        &#39;location&#39;=>&#39;http://10.0.0.232:1075/soap/ts1.php&#39;,
        &#39;uri&#39;=>&#39;sampleA&#39;
        ));
echo $client->sayHi(&#39;Taylor,Swift&#39;);
echo "<br/>";
echo $client->add(1,2);

Côté client, utilisez l'objet SoapClient pour faire des requêtes, l'emplacement spécifie l'adresse spécifique de la requête et la valeur uri est le même que celui défini côté serveur, utilisé pour garantir la cohérence.

Entrez http://10.0.0.232:1075/soap/tc1.php dans le navigateur pour y accéder. Vous pouvez voir le résultat comme indiqué ci-dessous :

Explication détaillée du savon php implémentant le service dinterface de service Web

.

Cette méthode n'a pas besoin de générer un document wsdl et est simple à mettre en œuvre. Cependant, comme il n'y a pas de document wsdl, le client ne peut pas obtenir les méthodes d'opération pertinentes. Avec la méthode de génération d'un document wsdl, le client peut effectuer. la requête basée sur une adresse de requête uniquement. Obtenez toutes les interfaces exposées par le serveur.

Comment générer un document wsdl

Le document wsdl est un document XML, qui peut généralement être généré à l'aide de la bibliothèque de classes publique SoapDiscovery. Je peux le partager avec Baidu Netdisk si. nécessaire. Téléchargez SoapDiscovery.class.php directement.

ts2.php côté serveur

<?php
define(&#39;WSDL_FILE&#39;,&#39;ts2.wsdl&#39;);
if(!file_exists(WSDL_FILE)){
        require_once(&#39;SoapDiscovery.class.php&#39;);
        $sd = new SoapDiscovery(&#39;testD&#39;, &#39;liang&#39;);
        $str = $sd->getWSDL();
        file_put_contents(WSDL_FILE, $str);
}
$ss = new SoapServer(WSDL_FILE);
$ss->setClass(&#39;testD&#39;);
$ss->handle();
class testD{
        public function sayHello($world){
                return &#39;hello,&#39;.$world;
        }
        public function add($a, $b){
                return $a+$b;
        }
}

Le ts2.php côté serveur vérifie d'abord si le fichier wsdl requis existe. S'il n'existe pas, créez-le, puis créez l'objet SoapServer. Et configurez-le, car vous utilisez un document wsdl, afin que vous puissiez écrire directement l'adresse du document wsdl lors de l'utilisation du nouveau SoapServer.

côté client tc2.php

<?php
$client = new SoapClient(&#39;http://10.0.0.232:1075/soap/ts2.wsdl&#39;);
print_r($client->__getFunctions());
echo "<br/>";
echo $client->sayHello(&#39;Avril Lavigne&#39;);
echo "<br/>";
echo $client->add(9,8);

Dans le fichier tc2.php côté client, lors de la création de l'objet SoapClient, l'adresse du document wsdl demandé est directement rempli. Ce document est généré par ts2.php.

Maintenant que le ts2.php côté serveur et le tc2.php côté client ont été écrits, vous devez demander ts2.php maintenant. Pourquoi le demander ?

Parce que nous devons d'abord créer le fichier wsdl via ts2.php. Bien sûr, nous n'avons besoin de le faire que pour la première fois. Une fois le document wsdl créé, il n'est pas nécessaire de le refaire.

(Si ts2.php est modifié ultérieurement, vous devez toujours supprimer l'ancien document wsdl, puis demander à nouveau ts2.php pour générer un nouveau document wsdl.)

1. .php est utilisé pour générer le document wsdl http://10.0.0.232:1075/soap/ts2.php.

2. Demandez tc2.php pour afficher les résultats renvoyés :

Explication détaillée du savon php implémentant le service dinterface de service Web

3. Via le navigateur, accédez directement à l'adresse du document wsdl. voir le document wsdl Contenu spécifique :

Explication détaillée du savon php implémentant le service dinterface de service Web

php soap prend également en charge diverses autres opérations, telles que l'authentification, les paramètres d'en-tête, etc. Si nécessaire, vous pouvez vous référer à la documentation officielle pour ces fonctions.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer