Zend_Service_StrikeIron-Overview.xml 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 17175 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.service.strikeiron">
  5. <title>Zend_Service_StrikeIron</title>
  6. <para>
  7. <classname>Zend_Service_StrikeIron</classname> bietet einen <acronym>PHP</acronym> 5
  8. Clienten zu den Web Services von StrikeIron. Siehe die folgenden Sektionen:
  9. </para>
  10. <para>
  11. <itemizedlist>
  12. <listitem><para><xref linkend="zend.service.strikeiron" /></para></listitem>
  13. </itemizedlist>
  14. <itemizedlist>
  15. <listitem>
  16. <para><xref linkend="zend.service.strikeiron.bundled-services" /></para>
  17. </listitem>
  18. </itemizedlist>
  19. <itemizedlist>
  20. <listitem>
  21. <para><xref linkend="zend.service.strikeiron.advanced-uses" /></para>
  22. </listitem>
  23. </itemizedlist>
  24. </para>
  25. <sect2 id="zend.service.strikeiron.overview">
  26. <title>Übersicht</title>
  27. <para>
  28. <ulink url="http://www.strikeiron.com">StrikeIron</ulink> bietet hunderte von
  29. kommerziellen Daten Services ("Daten als Service") wie z.B. Online Steuer, Wärungsraten,
  30. Aktienwerte, Geocodes, Globale Adresen Prüfung, Yallow/White Pages, MapQuest
  31. Fahranleitungen, Dun &amp; Bradstreet Business Credit Prüfungen, und viele, viele mehr.
  32. </para>
  33. <para>
  34. Jedes StrikeIron Web Service bietet eine standard <acronym>SOAP</acronym> (und REST)
  35. <acronym>API</acronym>, die die Integration und Handhabung mehrerer Services sehr einfach
  36. macht. StrikeIron managt auch die Kundenverrechnung für alle Services in einem einzelnen
  37. Account, was es für Lösungsanbieter perfekt macht. Man kann mit freien WebServices unter
  38. <ulink url="http://www.strikeiron.com/sdp">http://www.strikeiron.com/sdp</ulink> starten.
  39. </para>
  40. <para>
  41. Die Services von StrikeIron können schon alleine durch die
  42. <ulink url="http://us.php.net/soap">PHP 5 <acronym>SOAP</acronym> Erweiterung</ulink>
  43. verwendet werden. Trotzdem bietet die Verwendung von StrikeIron auf diesem Weg kein
  44. ideales <acronym>PHP</acronym>-artiges Interface. Die
  45. <classname>Zend_Service_StrikeIron</classname> Componente bietet einen leichtgewichtigen
  46. Layer aufbauend auf der <acronym>SOAP</acronym> Erweiterung für die Arbeit mit den
  47. Services von StrikeIron auf einem bequemeren und <acronym>PHP</acronym>-artigeren Weg.
  48. </para>
  49. <note>
  50. <para>
  51. Die <acronym>PHP</acronym> 5 <acronym>SOAP</acronym> Erweiterung muß installiert und
  52. aktiviert sein um <classname>Zend_Service_StrikeIron</classname> zu verwenden.
  53. </para>
  54. </note>
  55. <para>
  56. Die <classname>Zend_Service_StrikeIron</classname> Komponente bietet:
  57. <itemizedlist>
  58. <listitem>
  59. <para>
  60. Einen einzigen Punkt für die Konfiguration der eigenen Authentifizierungsdaten für
  61. StrikeIron die durch alle StrikeIron Services hinweg verwendet werden können.
  62. </para>
  63. </listitem>
  64. <listitem>
  65. <para>
  66. Einen standardtisierten Weg um die eigenen StrikeIron Einwahl Informationen wie den
  67. Lizenz Status und die Anzahl von verbleibenden Hits zu einem Service zu erhalten.
  68. </para>
  69. </listitem>
  70. <listitem>
  71. <para>
  72. Die Möglichkeit jedes StrikeIron Service von deren WSDL aus zu verwenden ohne eine
  73. <acronym>PHP</acronym> Wrapper Klasse zu erstellen, und die Option einen Wrapper für
  74. ein bequemeres Interface zu erstellen.
  75. </para>
  76. </listitem>
  77. <listitem>
  78. <para>
  79. Wrapper für drei populäre StrikeIron Services.
  80. </para>
  81. </listitem>
  82. </itemizedlist>
  83. </para>
  84. </sect2>
  85. <sect2 id="zend.service.strikeiron.registering">
  86. <title>Registrieren mit StrikeIron</title>
  87. <para>
  88. Bevor man mit <classname>Zend_Service_StrikeIron</classname> beginnen kann, muß man sich
  89. zuerst für einen StrikeIron Entwickler Zugang <ulink
  90. url="http://strikeiron.com/Register.aspx">registrieren</ulink>.
  91. </para>
  92. <para>
  93. Nach der Registrierung erhält man einen StrikeIron Benutzernamen und ein Passwort. Diese
  94. werden Verwendet wenn man sich auf StrikeIron verbindet indem man
  95. <classname>Zend_Service_StrikeIron</classname> verwendet.
  96. </para>
  97. <para>
  98. Man muß sich auch für StrikeIron's Super Data Pack Web Service
  99. <ulink url="http://www.strikeiron.com/ProductDetail.aspx?p=257">anmelden</ulink>.
  100. </para>
  101. <para>
  102. Beide Schritte der Registrierung sind frei und können relativ schnell mit der WebSeite von
  103. StrikeIron durchgeführt werden.
  104. </para>
  105. </sect2>
  106. <sect2 id="zend.service.strikeiron.getting-started">
  107. <title>Beginnen</title>
  108. <para>
  109. Sobald man sich für einen StrikeIron Account
  110. <ulink url="http://strikeiron.com/Register.aspx">registriert</ulink> und für das <ulink
  111. url="http://www.strikeiron.com/ProductDetail.aspx?p=257">Super Data Pack</ulink>
  112. angemeldet hat, ist man für die Benutzung von <classname>Zend_Service_StrikeIron</classname>
  113. bereit.
  114. </para>
  115. <para>
  116. StrikeIron besteht aus hunderten von verschiedenen WebServices.
  117. <classname>Zend_Service_StrikeIron</classname> kann mit vielen dieser Services verwendet
  118. werden bietet aber nur für drei von Ihnen unterstützte Wrapper:
  119. </para>
  120. <itemizedlist>
  121. <listitem>
  122. <para>
  123. <link linkend="zend.service.strikeiron.bundled-services.zip-code-information">ZIP Code
  124. Informationen</link>
  125. </para>
  126. </listitem>
  127. <listitem>
  128. <para>
  129. <link linkend="zend.service.strikeiron.bundled-services.us-address-verification">US
  130. Addressen Prüfung</link>
  131. </para>
  132. </listitem>
  133. <listitem>
  134. <para>
  135. <link linkend="zend.service.strikeiron.bundled-services.sales-use-tax-basic">Verkaufs-
  136. &amp; Steuergrundlagen</link>
  137. </para>
  138. </listitem>
  139. </itemizedlist>
  140. <para>
  141. Die Klasse <classname>Zend_Service_StrikeIron</classname> bietet einen einfachen Web um die
  142. eigenen Account Informationen von StrikeIron und andere Option im Konstruktor zu
  143. spezifizieren. Sie bietet auch eine Factory Methode die Clients für StrikeIron Services
  144. zurück gibt:
  145. <programlisting language="php"><![CDATA[
  146. $strikeIron = new Zend_Service_StrikeIron(array('username' => 'your-username',
  147. 'password' => 'your-password'));
  148. $taxBasic = $strikeIron->getService(array('class' => 'SalesUseTaxBasic'));
  149. ]]></programlisting>
  150. </para>
  151. <para>
  152. Die <methodname>getService()</methodname> Methode gibt einen Client für irgendein StrikeIron
  153. Service zurück das durch den Namen seiner <acronym>PHP</acronym> Wrapper Klasse definiert
  154. wurde. In diesem Fall, referiert der Name <code>SalesUseTaxBasic</code> zu der Wrapper
  155. Klasse <classname>Zend_Service_StrikeIron_SalesUseTaxBasic</classname>. Wrapper sind für
  156. drei Services inkludiert und in <link
  157. linkend="zend.service.strikeiron.bundled-services">Bundled Services</link> beschrieben.
  158. </para>
  159. <para>
  160. Die <methodname>getService()</methodname> Methode kann auch einen Client für ein StrikeIron
  161. Service zurückgeben das bisher keinen <acronym>PHP</acronym> Wrapper hat. Das wird in <link
  162. linkend="zend.service.strikeiron.advanced-uses.services-by-wsdl">Services durch WSDL
  163. verwenden</link> erklärt.
  164. </para>
  165. </sect2>
  166. <sect2 id="zend.service.strikeiron.making-first-query">
  167. <title>Die erste Abfrage durchführen</title>
  168. <para>
  169. Sobald die <methodname>getService()</methodname> Methode verwendet wurde um einen Clienten
  170. für ein gewünschtes StrikeIron Service zu erhalten, kann dieser Client verwendet werden
  171. durch Aufruf seiner Methoden ganz wie jedes andere PHP Objekt.
  172. <programlisting language="php"><![CDATA[
  173. $strikeIron = new Zend_Service_StrikeIron(array('username' => 'your-username',
  174. 'password' => 'your-password'));
  175. // Einen Client für das Verkaufs / Steuerbasis Service erhalten
  176. $taxBasic = $strikeIron->getService(array('class' => 'SalesUseTaxBasic'));
  177. // Steuerrate für Ontario, Canada abfragen
  178. $rateInfo = $taxBasic->getTaxRateCanada(array('province' => 'ontario'));
  179. echo $rateInfo->province;
  180. echo $rateInfo->abbreviation;
  181. echo $rateInfo->GST;
  182. ]]></programlisting>
  183. Im obigen Beispiel wird die <methodname>getService()</methodname> Methode verwendet um einen
  184. Client zum <link
  185. linkend="zend.service.strikeiron.bundled-services.sales-use-tax-basic">Verkaufs- &amp;
  186. Steuergrundlagen</link> Service zu erhalten. Das Client Objekt wird in
  187. <varname>$taxBasic</varname> gespeichert.
  188. </para>
  189. <para>
  190. Die <methodname>getTaxRateCanada()</methodname> Methode wird dann vom Service aus
  191. aufgerufen. Ein assoziatives Array wird verwendet um der Methode Schlüssel Parameter
  192. anzugeben. Das ist der Weg auf dem alle StrikeIron Methoden aufgerufen werden.
  193. </para>
  194. <para>
  195. Das Ergebnis von <methodname>getTaxRateCanada()</methodname> wird in
  196. <varname>$rateInfo</varname> gespeichert und hat Eigenschaften wie <code>province</code> und
  197. <constant>GST</constant>.
  198. </para>
  199. <para>
  200. Viele der Services von StrikeIron sind so einfach wie das obige Beispiel. Siehe
  201. <link linkend="zend.service.strikeiron.bundled-services">mitgelieferte Services</link> für
  202. detailierte Informationen zu drei der Services von StrikeIron.
  203. </para>
  204. </sect2>
  205. <sect2 id="zend.service.strikeiron.examining-results">
  206. <title>Ergebnisse betrachten</title>
  207. <para>
  208. Wenn man Services von StrikeIron lernt oder versucht fehler zu beheben, ist es oft nützlich
  209. das Ergebnis das von einem Methodenaufruf zurückgegeben wird auszugeben. Das Ergebnis wird
  210. immer ien Objekt sein das eine Instanz von
  211. <classname>Zend_Service_StrikeIron_Decorator</classname> ist. Das ist ein kleines <ulink
  212. url="http://en.wikipedia.org/wiki/Decorator_pattern">Dekorator</ulink> Objekt das die
  213. Ergebnisse des Methoden Aufrufs ummantelt.
  214. </para>
  215. <para>
  216. Der einfachste Weg ein Ergebnis vom Service zu betrachten ist die Verwendung der eingebauten
  217. PHP Methode <ulink url="http://www.php.net/print_r">print_r()</ulink>:
  218. <programlisting language="php"><![CDATA[
  219. $strikeIron = new Zend_Service_StrikeIron(array('username' => 'your-username',
  220. 'password' => 'your-password'));
  221. $taxBasic = $strikeIron->getService(array('class' => 'SalesUseTaxBasic'));
  222. $rateInfo = $taxBasic->getTaxRateCanada(array('province' => 'ontario'));
  223. print_r($rateInfo);
  224. ?>
  225. Zend_Service_StrikeIron_Decorator Object
  226. (
  227. [_name:protected] => GetTaxRateCanadaResult
  228. [_object:protected] => stdClass Object
  229. (
  230. [abbreviation] => ON
  231. [province] => ONTARIO
  232. [GST] => 0.06
  233. [PST] => 0.08
  234. [total] => 0.14
  235. [HST] => Y
  236. )
  237. )
  238. ]]></programlisting>
  239. </para>
  240. <para>
  241. In der obigen Ausgabe sehen wir das der Dekorator (<varname>$rateInfo</varname>) ein Objekt
  242. ummantelt das <code>GetTaxRateCanadaResult</code> heißt, und das Ergebnis des Aufrufes von
  243. <methodname>getTaxRateCanada()</methodname> ist.
  244. </para>
  245. <para>
  246. Das bedeutet das <varname>$rateInfo</varname> öffentliche Eigenschaften wie
  247. <code>abbreviation</code>, <code>province</code>, und <constant>GST</constant> hat. Dieser
  248. werden z.B. mit <code>$rateInfo->province</code> aufgerufen.
  249. </para>
  250. <tip>
  251. <para>
  252. Die Eigenschaften von StrikeIron Ergebnissen beginnen oft mit einem Großbuchstaben wie
  253. <code>Foo</code> oder <code>Bar</code> wobei die meisten <acronym>PHP</acronym> Objekt
  254. Eigenschaften normalerweise mit einem Kleinbuchstaben wie <code>foo</code> oder
  255. <code>bar</code> beginnen. Der Dekorator wird diesen Eingriff automatisch durchführen
  256. sodas eine Eigenschaft von <code>Foo</code> als <code>foo</code> gelesen werden kann.
  257. </para>
  258. </tip>
  259. <para>
  260. Wenn man jemals das originale Objekt oder seinen Namen vom Dekorator heraus benötigt können
  261. die Methoden <methodname>getDecoratedObject()</methodname> und
  262. <methodname>getDecoratedObjectName()</methodname> verwendet werden.
  263. </para>
  264. </sect2>
  265. <sect2 id="zend.service.strikeiron.handling-errors">
  266. <title>Fehler handhaben</title>
  267. <para>
  268. Die vorigen Beispiel sind naiv, was bedeutet das keine Handhabung von Fehlern gezeigt wurde.
  269. Es ist möglich das StrikeIron einen Fehler zurückgibt wärend des Aufrufs einer Methode.
  270. Selbst fehlerhafte Account Daten oder ein abgelaufener Zugang kann StrikeIron dazu bringen
  271. einen Fehler zu werfen.
  272. </para>
  273. <para>
  274. Eine Ausnahme wird geworfen wenn solch ein Fehler auftritt. Man sollte das berücksichtigen
  275. und solche Ausnahmen fangen wenn man Methodenaufrufe zu einem Service durchführt:
  276. <programlisting language="php"><![CDATA[
  277. $strikeIron = new Zend_Service_StrikeIron(array('username' => 'your-username',
  278. 'password' => 'your-password'));
  279. $taxBasic = $strikeIron->getService(array('class' => 'SalesUseTaxBasic'));
  280. try {
  281. $taxBasic->getTaxRateCanada(array('province' => 'ontario'));
  282. } catch (Zend_Service_StrikeIron_Exception $e) {
  283. // Fehler handhaben für Events wie Verbindungsprobleme oder Account Probleme
  284. }
  285. ]]></programlisting>
  286. Die geworfenen Ausnahmen werden immer
  287. <classname>Zend_Service_StrikeIron_Exception</classname> sein.
  288. </para>
  289. <para>
  290. Es ist wichtig die Unterschiede zwischen Ausnahmen und normalen fehlgeschlagenen
  291. Methodenaufrufen zu verstehen. Ausnahmen treten für <emphasis>ausgenommene</emphasis>
  292. Verhaltenweisen auf, wie z.B. ein Netzwerk das abstürzt oder ein abgelaufener Account.
  293. Fehlgeschlagene Methodenaufrufe die häufig auftreten, wie z.B. wenn
  294. <methodname>getTaxRateCanada()</methodname> die angegebene <code>province</code> nicht
  295. findet, führen nicht dazu das Ausnahmen geworfen werden.
  296. </para>
  297. <note>
  298. <para>
  299. Jedesmal wenn ein Methodenaufruf zu einem Service von StrikeIron durchgeführt wird, sollte
  300. das Ergebnis Objekt auf Gültigkeit geprüft werden und man sollte genauso vorsehen eine
  301. Ausnahme zu fangen.
  302. </para>
  303. </note>
  304. <para><!-- inkludiert für Leerzeichen --></para>
  305. </sect2>
  306. <sect2 id="zend.service.strikeiron.checking-subscription">
  307. <title>Den eigenen Account prüfen</title>
  308. <para>
  309. StrikeIron bietet viele verschiedene Services. Einige von Ihnen sind kostenlos, eine sind
  310. auf einer Testbasis vorhanden, und einige sind nur für zahlende Kunden. Wenn StrikeIron
  311. verwendet wird, ist es wichtig auf den Account Status für die Services zu achten die man
  312. verwendet und diesen regelmäßig zu prüfen.
  313. </para>
  314. <para>
  315. Jeder StrikeIron Client, der von der <code>getService</code> Methode zurückgegeben wird, hat
  316. die Möglichkeit den Account Status für diesen Service zu prüfen indem die
  317. <methodname>getSubscriptionInfo()</methodname> Methode dieses Clients verwendet wird:
  318. <programlisting language="php"><![CDATA[
  319. // Einen Client für das Verkaufs / Steuerbasis Service erhalten
  320. $strikeIron = new Zend_Service_StrikeIron(array('username' => 'your-username',
  321. 'password' => 'your-password'));
  322. $taxBasic = $strikeIron->getService(array('class => 'SalesUseTaxBasic'));
  323. // Prüfe die noch möglichen Zugriffe für das Verkaufs- & Steuerbasis Service
  324. $subscription = $taxBasic->getSubscriptionInfo();
  325. echo $subscription->remainingHits;
  326. ]]></programlisting>
  327. </para>
  328. <para>
  329. Die <methodname>getSubscriptionInfo()</methodname> Methode gibt ein Objekt zurück, das
  330. typischerweise eine <code>remainingHits</code> Eigenschaft hat. Es ist wichtig den Status,
  331. für jeden Service der verwendet wird, zu prüfen. Wenn ein Methodenaufruf zu StrikeIron
  332. gemacht wird, nachdem die möglichen Zugriffe aufgebraucht wurden, wird eine Ausnahme
  333. auftreten.
  334. </para>
  335. <para>
  336. Das Prüfen des Accounts zu einem Service benötigt keinen Zugriff (hit) auf diesen Server.
  337. Jedes Mal wenn irgendein Methodenaufruf zu einem Service gemacht wurde, wird die Anzahl der
  338. möglichen Zugriffe gecached und dieser gecachete Wert wird durch
  339. <methodname>getSubscriptionInfo()</methodname> zurückgegeben ohne das noch einmal mit dem
  340. Service eine Verbindung aufgebaut werden muß. Um
  341. <methodname>getSubscriptionInfo()</methodname> dazu zu bringen seinen Cache auszuschalten
  342. und die Account Informationen nochmals abzufragen, kann
  343. <methodname>getSubscriptionInfo(true)</methodname> verwendet werden.
  344. </para>
  345. </sect2>
  346. </sect1>