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

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

藏色散人
Freigeben: 2023-04-08 08:42:02
nach vorne
3518 Leute haben es durchsucht

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();
Nach dem Login kopieren

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);
Nach dem Login kopieren

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;
        }
}
Nach dem Login kopieren

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);
Nach dem Login kopieren

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!

Verwandte Etiketten:
php
Quelle:csdn.net
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage