Zend_Service_StrikeIron: Erweiterte Verwendung
Diese Sektion beschreibt die erweiterte Verwendung von
Zend_Service_StrikeIron.
Die Services durch WSDL verwenden
Für einige StrikeIron Services können PHP Wrapper Klassen vorhanden
sein, so wie jene die in Bundled Services
beschrieben werden. Trotzdem bietet StrikeIron hunderte von Services und viele von
diesen können nicht verwendbar sein wenn keine spezielle Wrapper Klasse erstellt wird.
Um ein StrikeIron Service zu probieren für das keine Wrapper Klasse vorhanden ist, muß
die wsdl Option statt der class Option an
getService() übergeben werden:
'your-username', 'password' => 'your-password')
);
// Erhalte einen generellen Client zum Reverse Phone Lookup Service
$phone = $strikeIron->getService(
array('wsdl' => 'http://ws.strikeiron.com/ReversePhoneLookup?WSDL')
);
$result = $phone->lookup(array('Number' => '(408) 253-8800'));
echo $result->listingName;
// Zend Technologies USA Inc
]]>
Um StrikeIron Services durch WSDL zu verwenden wird zumindest ein Verständnis für WSDL
Dateien benötigt. StrikeIron hat viele Ressourcen auf Ihren Seiten die hierbei helfen.
Auch Jan Schneider vom
Horde Projekt hat eine kleine PHP
Routine geschrieben die eine WSDL Datei in lesbares HTML
konvertiert.
Es ist zu beachten das nur die Services die in der
Mitgelieferten Services
Sektion beschrieben werden auch offiziell unterstützt werden.
SOAP Transaktionen betrachten
Die gesamte Kommunikation mit StrikeIron wird durch Verwenden der
SOAP Erweiterung durchgeführt. Es kann zeitweise nützlich sein das
mit StrikeIron getauschte XML für Debugging Zwecke zu betrachten.
Jeder StrikeIron Client (Subklasse von
Zend_Service_StrikeIron_Base) enthält eine
getSoapClient() Methode um die darunterliegende Instanz von
SOAPClient zu retournieren, die für die Kommunikation mit
StrikeIron verwendet wird.
PHP's SOAPClient
hat eine trace Option die dazu führt dass das
XML, das während der letzten Transaktion getauscht wurde, gemerkt
wird. Zend_Service_StrikeIron aktiviert die
trace Option nicht standardmäßig aber das kann einfach getan werden
durch Spezifizierung der Option die dazu verwendet wird den
SOAPClient Konstruktor zu übergeben.
Um die SOAP Transaktion zu betrachten muß die getSoapClient()
Methode aufgerufen werden um die SOAPClient Instanz zu erhalten
und anschließend die entsprechenden Methoden wie __getLastRequest()
und __getLastRequest():
aufzurufen:
'your-username',
'password' => 'your-password',
'options' => array('trace' => true)));
// Erstelle einen Client für das Verkaufs & Verwende Steuer BasisService
$taxBasic = $strikeIron->getService(array('class' => 'SalesUseTaxBasic'));
// Einen Methodenaufruf durchführen
$taxBasic->getTaxRateCanada(array('province' => 'ontario'));
// Die SOAPClient Instanz holen und das XML ansehen
$soapClient = $taxBasic->getSoapClient();
echo $soapClient->__getLastRequest();
echo $soapClient->__getLastResponse();
]]>