Zend_Service_StrikeIron-Overview.xml 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 17175 -->
  4. <sect1 id="zend.service.strikeiron">
  5. <title>Zend_Service_StrikeIron</title>
  6. <para>
  7. <classname>Zend_Service_StrikeIron</classname> は、StrikeIron
  8. ウェブサービス用の <acronym>PHP</acronym> 5 クライアントです。以下のセクションを参照ください。
  9. </para>
  10. <para>
  11. <itemizedlist>
  12. <listitem><para><xref linkend="zend.service.strikeiron" /></para></listitem>
  13. </itemizedlist>
  14. <itemizedlist>
  15. <listitem><para><xref linkend="zend.service.strikeiron.bundled-services" /></para></listitem>
  16. </itemizedlist>
  17. <itemizedlist>
  18. <listitem><para><xref linkend="zend.service.strikeiron.advanced-uses" /></para></listitem>
  19. </itemizedlist>
  20. </para>
  21. <sect2 id="zend.service.strikeiron.overview">
  22. <title>概要</title>
  23. <para>
  24. <ulink url="http://www.strikeiron.com">StrikeIron</ulink>
  25. は、さまざまな商用データサービス ("Data as a Service") を提供しています。たとえば
  26. Online Sales Tax, Currency Rates, Stock Quotes, Geocodes, Global
  27. Address Verification, Yellow/White Pages, MapQuest Driving Directions,
  28. Dun &amp; Bradstreet Business Credit Checks などのサービスがあります。
  29. </para>
  30. <para>
  31. StrikeIron ウェブサービスの各サービスは、標準の <acronym>SOAP</acronym> (および REST)
  32. <acronym>API</acronym> を共有しています。これにより、複数のサービスを統合して管理するのが簡単になります。
  33. StrikeIron はまた、すべてのサービスの支払いを単一のアカウントで管理しています。
  34. ソリューションプロバイダにとって完璧な環境といえます。
  35. <ulink url="http://www.strikeiron.com/sdp">http://www.strikeiron.com/sdp</ulink>
  36. で、フリーなウェブサービスを試してみましょう。
  37. </para>
  38. <para>
  39. StrikeIron のサービスは、
  40. <ulink url="http://jp.php.net/soap"><acronym>PHP</acronym> 5 の <acronym>SOAP</acronym> 拡張モジュール</ulink>
  41. のみでも使用することができるでしょう。
  42. しかし、StrikeIron をこの方法で使用すると、
  43. 真の <acronym>PHP</acronym> 風インターフェイスを活用することができません。
  44. <classname>Zend_Service_StrikeIron</classname> コンポーネントは、<acronym>SOAP</acronym>
  45. 拡張モジュールの上にもう一枚薄い皮をかぶせることによって、
  46. StrikeIron のサービスをより便利かつ <acronym>PHP</acronym>
  47. らしく使えるようにしています。
  48. </para>
  49. <note>
  50. <para>
  51. <classname>Zend_Service_StrikeIron</classname> を使うには、
  52. <acronym>PHP</acronym> 5 の <acronym>SOAP</acronym> 拡張モジュールがインストールされて有効になっている必要があります。
  53. </para>
  54. </note>
  55. <para>
  56. <classname>Zend_Service_StrikeIron</classname> コンポーネントが提供する機能を以下にまとめます。
  57. <itemizedlist>
  58. <listitem>
  59. <para>
  60. StrikeIron の認証情報の一元管理により、
  61. さまざまな StrikeIron サービスで使用可能。
  62. </para>
  63. </listitem>
  64. <listitem>
  65. <para>
  66. StrikeIron のさまざまな登録情報
  67. (ライセンスの状態や残りの使用回数など)
  68. の標準的な方法での取得。
  69. </para>
  70. </listitem>
  71. <listitem>
  72. <para>
  73. <acronym>PHP</acronym> のラッパークラスを作成しなくても、WSDL
  74. だけで StrikeIcon サービスが使用可能。
  75. また、ラッパーを作成することで、
  76. より便利なインターフェイスを使用することも可能。
  77. </para>
  78. </listitem>
  79. <listitem>
  80. <para>
  81. StrikeIron のサービスのうち、人気のある 3 つについてのラッパー。
  82. </para>
  83. </listitem>
  84. </itemizedlist>
  85. </para>
  86. </sect2>
  87. <sect2 id="zend.service.strikeiron.registering">
  88. <title>StrikeIron への登録</title>
  89. <para>
  90. <classname>Zend_Service_StrikeIron</classname> を使用するには、まず
  91. StrikeIron 開発者アカウントを取得するために
  92. <ulink url="http://strikeiron.com/Register.aspx">登録</ulink>
  93. する必要があります。
  94. </para>
  95. <para>
  96. 登録したら、StrikeIron のユーザ名とパスワードを受け取ります。
  97. <classname>Zend_Service_StrikeIron</classname> で StrikeIron に接続する際には、
  98. このユーザ名とパスワードを使用します。
  99. </para>
  100. <para>
  101. また、StrikeIron の Super Data Pack Web Service にも
  102. <ulink url="http://www.strikeiron.com/ProductDetail.aspx?p=257">登録</ulink>
  103. する必要があります。
  104. </para>
  105. <para>
  106. どちらの登録処理も無料です。
  107. StrikeIron のウェブサイト上で比較的速やかに行えます。
  108. </para>
  109. </sect2>
  110. <sect2 id="zend.service.strikeiron.getting-started">
  111. <title>では、はじめましょう</title>
  112. <para>
  113. StrikeIron のアカウントを
  114. <ulink url="http://strikeiron.com/Register.aspx">取得</ulink>
  115. して
  116. <ulink url="http://www.strikeiron.com/ProductDetail.aspx?p=257">Super Data Pack</ulink>
  117. にも参加したら、<classname>Zend_Service_StrikeIron</classname>
  118. を使うための準備は完了です。
  119. </para>
  120. <para>
  121. StrikeIron には何百ものさまざまなウェブサービスが存在します。
  122. Zend_Service_StrikeIron はこれらのサービスの多くで利用可能ですが、
  123. 特に以下の 3 つについてはラッパークラスを用意しています。
  124. </para>
  125. <itemizedlist>
  126. <listitem>
  127. <para><link linkend="zend.service.strikeiron.bundled-services.zip-code-information">ZIP Code Information</link></para>
  128. </listitem>
  129. <listitem>
  130. <para><link linkend="zend.service.strikeiron.bundled-services.us-address-verification">US Address Verification</link></para>
  131. </listitem>
  132. <listitem>
  133. <para><link linkend="zend.service.strikeiron.bundled-services.sales-use-tax-basic">Sales &amp; Use Tax Basic</link></para>
  134. </listitem>
  135. </itemizedlist>
  136. <para>
  137. <classname>Zend_Service_StrikeIron</classname> クラスには、
  138. そのコンストラクタで StrikeIron アカウント情報やその他のオプションを設定することができます。
  139. また、StrikeIron の各種サービス用のクライアントを帰すファクトリメソッドも用意しています。
  140. <programlisting language="php"><![CDATA[
  141. $strikeIron = new Zend_Service_StrikeIron(array('username' => 'あなたのユーザ名',
  142. 'password' => 'あなたのパスワード'));
  143. $taxBasic = $strikeIron->getService(array('class' => 'SalesUseTaxBasic'));
  144. ]]></programlisting>
  145. </para>
  146. <para>
  147. <methodname>getService()</methodname> メソッドは、StrikeIron
  148. のサービス用のクライアントを帰します。引数には
  149. <acronym>PHP</acronym> のラッパークラスの名前を指定します。
  150. この場合の <code>SalesUseTaxBasic</code> は、ラッパークラス
  151. <classname>Zend_Service_StrikeIron_SalesUseTaxBasic</classname>
  152. を指しています。標準で組み込まれている 3 つのラッパーについては
  153. <link linkend="zend.service.strikeiron.bundled-services">バンドルされているサービス</link>
  154. で説明します。
  155. </para>
  156. <para>
  157. <methodname>getService()</methodname> は、対応する <acronym>PHP</acronym>
  158. ラッパーを持たない StrikeIron サービス用のクライアントも返すことができます。
  159. この機能については
  160. <link linkend="zend.service.strikeiron.advanced-uses.services-by-wsdl">WSDL によるサービスの使用</link>
  161. で説明します。
  162. </para>
  163. </sect2>
  164. <sect2 id="zend.service.strikeiron.making-first-query">
  165. <title>はじめてのクエリ</title>
  166. <para>
  167. <methodname>getService()</methodname> で StrikeIron サービス用のクライアントを取得したら、
  168. あとは普通の <acronym>PHP</acronym> オブジェクトと同様にそのメソッドをコールすることができます。
  169. <programlisting language="php"><![CDATA[
  170. $strikeIron = new Zend_Service_StrikeIron(array('username' => 'あなたのユーザ名',
  171. 'password' => 'あなたのパスワード'));
  172. // Sales & Use Tax Basic サービス用のクライアントを取得します
  173. $taxBasic = $strikeIron->getService(array('class' => 'SalesUseTaxBasic'));
  174. // カナダのオンタリオ州の税率を取得します
  175. $rateInfo = $taxBasic->getTaxRateCanada(array('province' => 'ontario'));
  176. echo $rateInfo->province;
  177. echo $rateInfo->abbreviation;
  178. echo $rateInfo->GST;
  179. ]]></programlisting>
  180. 上の例では、<methodname>getService()</methodname> メソッドを使用して
  181. <link linkend="zend.service.strikeiron.bundled-services.sales-use-tax-basic">Sales &amp; Use Tax Basic</link>
  182. サービス用のクライアントを取得しています。
  183. 取得したオブジェクトは <code>$taxBasic</code> に保存します。
  184. </para>
  185. <para>
  186. 次に、そのサービスの <methodname>getTaxRateCanada()</methodname>
  187. メソッドをコールします。メソッドに対してキーワードパラメータを渡すには
  188. 連想配列を使用します。これは、すべての StrikeIron
  189. のメソッドで共通の方法です。
  190. </para>
  191. <para>
  192. <methodname>getTaxRateCanada()</methodname> の返り値を
  193. <code>$rateInfo</code> に取得し、そのプロパティ <code>province</code>
  194. や <constant>GST</constant> を参照しています。
  195. </para>
  196. <para>
  197. StrikeIron のサービスの多くは、この例と同じくらい簡単に使用できます。
  198. 3 つの StrikeIron サービスについての詳細は
  199. <link linkend="zend.service.strikeiron.bundled-services">バンドルされているサービス</link>
  200. を参照ください。
  201. </para>
  202. </sect2>
  203. <sect2 id="zend.service.strikeiron.examining-results">
  204. <title>結果の吟味</title>
  205. <para>
  206. StrikeIron サービスについて学習したりデバッグしたりする際には、
  207. メソッドから返された内容を出力できると便利です。
  208. メソッドの返り値は常に
  209. <classname>Zend_Service_StrikeIron_Decorator</classname> のインスタンスとなります。
  210. これはちょっとした
  211. <ulink url="http://ja.wikipedia.org/wiki/Decorator_%E3%83%91%E3%82%BF%E3%83%BC%E3%83%B3">デコレータ</ulink>
  212. オブジェクトであり、メソッドのコール結果をラップしています。
  213. </para>
  214. <para>
  215. サービスが返した結果を調べる最も単純な方法は、
  216. <ulink url="http://www.php.net/print_r">print_r()</ulink>
  217. のような <acronym>PHP</acronym> の組み込み関数を使うことです。
  218. <programlisting language="php"><![CDATA[
  219. <?php
  220. $strikeIron = new Zend_Service_StrikeIron(array('username' => 'あなたのユーザ名',
  221. 'password' => 'あなたのパスワード'));
  222. $taxBasic = $strikeIron->getService(array('class' => 'SalesUseTaxBasic'));
  223. $rateInfo = $taxBasic->getTaxRateCanada(array('province' => 'ontario'));
  224. print_r($rateInfo);
  225. ?>
  226. Zend_Service_StrikeIron_Decorator Object
  227. (
  228. [_name:protected] => GetTaxRateCanadaResult
  229. [_object:protected] => stdClass Object
  230. (
  231. [abbreviation] => ON
  232. [province] => ONTARIO
  233. [GST] => 0.06
  234. [PST] => 0.08
  235. [total] => 0.14
  236. [HST] => Y
  237. )
  238. )
  239. ]]></programlisting>
  240. </para>
  241. <para>
  242. 上の例でわかるように、デコレータ (<code>$rateInfo</code>) が
  243. <code>GetTaxRateCanadaResult</code> というオブジェクトをラップしています。
  244. これが <methodname>getTaxRateCanada()</methodname> の返り値です。
  245. </para>
  246. <para>
  247. この結果から、<code>$rateInfo</code> には <code>abbreviation</code>
  248. や <code>province</code>、<constant>GST</constant>
  249. といった公開プロパティがあることがわかります。これらは
  250. <code>$rateInfo->province</code> のようにしてアクセスできます。
  251. </para>
  252. <tip>
  253. <para>
  254. StrikeIron の結果のプロパティは、場合によっては大文字で始まっていることもあります
  255. (<code>Foo</code> や <code>Bar</code> など)。一方、たいていの <acronym>PHP</acronym>
  256. オブジェクトのプロパティは、普通は小文字で始まる形式 (<code>foo</code>
  257. や <code>bar</code> など) です。このあたりはデコレータがうまく処理するので、
  258. プロパティが <code>Foo</code> であっても
  259. <code>foo</code> として取得できるようになります。
  260. </para>
  261. </tip>
  262. <para>
  263. もしデコレータではなく中身のオブジェクトそのものやその名前がほしい場合は、
  264. それぞれ <methodname>getDecoratedObject()</methodname> および
  265. <methodname>getDecoratedObjectName()</methodname> を使用します。
  266. </para>
  267. </sect2>
  268. <sect2 id="zend.service.strikeiron.handling-errors">
  269. <title>エラー処理</title>
  270. <para>
  271. 先ほどの例はあまりにも無邪気すぎるところがありました。
  272. エラー処理を一切していなかったのです。
  273. メソッドをコールした際に、StrikeIron がエラーを返す可能性だってあります。
  274. 認証情報が間違っていたり、アカウントが有効期限切れになっていた場合などに
  275. StrikeIron はエラーを発します。
  276. </para>
  277. <para>
  278. このような場合は例外がスローされます。
  279. 例外が発生することを想定して、
  280. サービスのメソッドをコールする際には例外処理を書く必要があります。
  281. <programlisting language="php"><![CDATA[
  282. $strikeIron = new Zend_Service_StrikeIron(array('username' => 'あなたのユーザ名',
  283. 'password' => 'あなたのパスワード'));
  284. $taxBasic = $strikeIron->getService(array('class' => 'SalesUseTaxBasic'));
  285. try {
  286. $taxBasic->getTaxRateCanada(array('province' => 'ontario'));
  287. } catch (Zend_Service_StrikeIron_Exception $e) {
  288. // 接続時のエラーなどの場合の
  289. // エラー処理をここで行います
  290. }
  291. ]]></programlisting>
  292. スローされる例外は、常に <classname>Zend_Service_StrikeIron_Exception</classname>
  293. となります。
  294. </para>
  295. <para>
  296. メソッドコール時の通常の失敗と例外の違いはしっかり把握しておきましょう。
  297. 例外が発生するのは、<emphasis>例外的な</emphasis>
  298. 状態です。たとえばネットワークの障害が発生したとか
  299. アカウントが有効期限切れになっていたとかいった状況がそれにあたります。
  300. 通常の失敗とは、もっと頻繁に起こりえるものです。
  301. たとえば <methodname>getTaxRateCanada()</methodname> で指定した
  302. <code>province</code> が見つけられないときなどは例外とはなりません。
  303. </para>
  304. <note>
  305. <para>
  306. StrikeIron サービスのメソッドをコールする際には
  307. 常に返り値をチェックするようにしましょう。
  308. もちろん例外処理も必要です。
  309. </para>
  310. </note>
  311. <para><!-- included for whitespace --></para>
  312. </sect2>
  313. <sect2 id="zend.service.strikeiron.checking-subscription">
  314. <title>購入内容の確認</title>
  315. <para>
  316. StrikeIron にはさまざまなサービスがあります。
  317. その中には無料で使えるものもあればお試し版のものもあります。
  318. また、有料サービスのみのものもあります。
  319. StrikeIron を使用するにあたっては、
  320. そのサービスの購入状況を常に確認することが必要です。
  321. </para>
  322. <para>
  323. <code>getService</code> メソッドが返す StrikeIron クライアントにはすべて、
  324. そのサービスの購入状況を調べる
  325. <methodname>getSubscriptionInfo()</methodname> メソッドが存在します。
  326. <programlisting language="php"><![CDATA[
  327. // Sales & Use Tax Basic サービス用のクライアントを取得します
  328. $strikeIron = new Zend_Service_StrikeIron(array('username' => 'あなたのユーザ名',
  329. 'password' => 'あなたのパスワード'));
  330. $taxBasic = $strikeIron->getService(array('class => 'SalesUseTaxBasic'));
  331. // Sales & Use Tax Basic サービスをあと何回使用できるかを調べます
  332. $subscription = $taxBasic->getSubscriptionInfo();
  333. echo $subscription->remainingHits;
  334. ]]></programlisting>
  335. </para>
  336. <para>
  337. <methodname>getSubscriptionInfo()</methodname> メソッドが返すオブジェクトの多くには、
  338. <code>remainingHits</code> プロパティが含まれます。
  339. これを調べて、使用しているサービスの状態を確認します。
  340. 残りの使用回数を超える数のメソッドコールを行うと、
  341. StrikeIron は例外をスローします。
  342. </para>
  343. <para>
  344. サービスの購入状況を調べる問い合わせを送っても、
  345. 残りの使用可能回数は減りません。
  346. サービスのメソッドをコールする際にはいつも残りの回数を自動的に取得します。
  347. この値は、サービスに接続しなくても
  348. <methodname>getSubscriptionInfo()</methodname> で取得することができます。
  349. キャッシュを使用せずにもう一度情報を問い合わせるよう
  350. <methodname>getSubscriptionInfo()</methodname> に指示するには、
  351. <methodname>getSubscriptionInfo(true)</methodname> とします。
  352. </para>
  353. </sect2>
  354. </sect1>