Heim  >  Artikel  >  Backend-Entwicklung  >  Detaillierte Erläuterung der Implementierung des Web-Service-Schnittstellendienstes durch PHP-Soap

Detaillierte Erläuterung der Implementierung des Web-Service-Schnittstellendienstes durch PHP-Soap

藏色散人
藏色散人nach vorne
2020-01-16 17:52:583382Durchsuche

Was ist ein Webdienst? Ich werde nicht auf Details eingehen. Sie können sich auf die Enzyklopädiebeschreibung Webdienst Baidu Enzyklopädie beziehen.

Soap ist ein Protokoll und eine technische Spezifikation, die bei der Implementierung von Webdiensten verwendet wird.

Es gibt zwei Möglichkeiten, die Schnittstelle des Webdienstes zu implementieren: Eine ist die Möglichkeit, ein WSDL-Dokument zu generieren, die andere ist die Möglichkeit, kein WSDL-Dokument zu generieren.

Überprüfen Sie vor dem eigentlichen Betrieb zunächst, ob Ihre Umgebung Soap unterstützt, ändern Sie dann die Konfigurationsdatei php.ini und setzen Sie das Element „soap.wsdl_cache_enabled“ auf 0.

Es ist nicht erforderlich, ein WSDL-Dokument zu generieren

Diese Methode ist einfacher als die Methode, die zum Generieren eines WSDL-Dokuments erforderlich ist, aber einige Methoden werden nicht unterstützt, z. B. Get the __getFunctions () der Operationsmethode hängt von Ihrer Wahl ab.

serverseitiges 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();

Erstellen Sie in der serverseitigen ts1.php-Datei eine Klasse, erstellen Sie dann SoapServer und nehmen Sie Einstellungen vor. URI wird verwendet, um die Konsistenz sicherzustellen Sex.

Client-Seite 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);

Verwenden Sie auf der Client-Seite das SoapClient-Objekt, um die Anforderung anzugeben Die URL ist dieselbe wie auf der Serverseite und wird verwendet, um die Konsistenz sicherzustellen.

Geben Sie http://10.0.0.232:1075/soap/tc1.php in den Browser ein, um darauf zuzugreifen. Sie können die Ausgabe wie unten gezeigt sehen:

Detaillierte Erläuterung der Implementierung des Web-Service-Schnittstellendienstes durch PHP-Soap

Diese Methode erfordert kein WSDL-Dokument und ist einfach zu implementieren. Da jedoch kein WSDL-Dokument vorhanden ist, kann der Client die entsprechenden Operationsmethoden nicht abrufen Die Anfrage basiert allein auf einer Anfrageadresse. Ruft alle vom Server bereitgestellten Schnittstellen ab.

So generieren Sie ein WSDL-Dokument

WSDL-Dokument ist ein XML-Dokument, das normalerweise mit der öffentlichen Klassenbibliothek SoapDiscovery generiert werden kann, wenn erforderlich. Laden Sie SoapDiscovery.class.php direkt herunter.

serverseitige ts2.php

<?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;
        }
}

Die serverseitige ts2.php prüft zunächst, ob die erforderliche WSDL-Datei vorhanden ist, erstellen Sie sie. Erstellen Sie dann das SoapServer-Objekt und richten Sie es ein, da Sie ein WSDL-Dokument verwenden, sodass Sie die Adresse des WSDL-Dokuments direkt schreiben können, wenn Sie einen neuen SoapServer verwenden.

clientseitiges 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);

In der tc2.php-Datei auf der Clientseite steht beim Erstellen des SoapClient-Objekts direkt die Adresse des angeforderten WSDL-Dokuments ausgefüllt. Dieses Dokument wird von ts2.php generiert.

Nachdem die serverseitige ts2.php und die clientseitige tc2.php geschrieben wurden, müssen Sie ts2.php jetzt anfordern.

Da wir die WSDL-Datei zuerst über ts2.php erstellen müssen, müssen wir dies natürlich nur zum ersten Mal tun, nachdem das WSDL-Dokument erstellt wurde.

(Wenn ts2.php später geändert wird, müssen Sie immer noch das alte WSDL-Dokument löschen und dann ts2.php erneut anfordern, um ein neues WSDL-Dokument zu generieren.)

1. Fordern Sie ts2 an .php wird zum Generieren des WSDL-Dokuments http://10.0.0.232:1075/soap/ts2.php verwendet.

2. Fordern Sie tc2.php an, um die zurückgegebenen Ergebnisse anzuzeigen:

Detaillierte Erläuterung der Implementierung des Web-Service-Schnittstellendienstes durch PHP-Soap

3. Über den Browser können Sie direkt auf die Adresse des WSDL-Dokuments zugreifen Weitere Informationen finden Sie im WSDL-Dokument. Spezifischer Inhalt:

Detaillierte Erläuterung der Implementierung des Web-Service-Schnittstellendienstes durch PHP-Soap

PHP Soap unterstützt auch verschiedene andere Vorgänge wie Authentifizierung, Header-Einstellungen usw. Bei Bedarf können Sie sich auf die offizielle Dokumentation beziehen diese Funktionen.

Das obige ist der detaillierte Inhalt vonDetaillierte Erläuterung der Implementierung des Web-Service-Schnittstellendienstes durch PHP-Soap. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:csdn.net. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen