Zend_Soap_Wsdl.xml 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 24249 -->
  4. <sect1 id="zend.soap.wsdl">
  5. <title>WSDLアクセッサ</title>
  6. <note>
  7. <para>
  8. WSDL文書による操作を行なうために、
  9. 内部的に<classname>Zend_Soap_Server</classname>コンポーネントによって<classname>Zend_Soap_Wsdl</classname>が使われます。
  10. それでも、このクラスにより提供される機能を独自の必要性によって使うこともできます。
  11. <classname>Zend_Soap_Wsdl</classname>パッケージは、パーサーとWSDL文書のビルダーを含みます。
  12. </para>
  13. <para>
  14. あなたに使う予定がなければ、この節を読み飛ばすことができます。
  15. </para>
  16. </note>
  17. <sect2 id="zend.soap.wsdl.constructor">
  18. <title>Zend_Soap_Wsdlコンストラクタ</title>
  19. <para>
  20. <classname>Zend_Soap_Wsdl</classname>コンストラクタは3つのパラメータをとります:
  21. <orderedlist>
  22. <listitem>
  23. <simpara><code>$name</code> - 記述されたウェブサービスの名前。</simpara>
  24. </listitem>
  25. <listitem>
  26. <simpara>
  27. <code>$uri</code> - WSDLが利用できる<acronym>URI</acronym>
  28. (ファイルシステムのファイルへのリファレンスでも可)
  29. </simpara>
  30. </listitem>
  31. <listitem>
  32. <simpara>
  33. <code>$strategy</code> - 複雑な型(オブジェクト)を検出する方策を
  34. 識別するために用いられるオプションのフラグです。
  35. これはバージョン1.7より前はブール値 <code>$extractComplexTypes</code>でしたが、
  36. 後方互換性のためにまだブール値として設定できます。
  37. デフォルトで、1.6の検出動作が設定されます。
  38. 複雑な型の検出の方策について詳しくは、この節をご覧下さい:
  39. <link linkend="zend.soap.wsdl.types.add_complex">複雑な型を追加</link>
  40. </simpara>
  41. </listitem>
  42. </orderedlist>
  43. </para>
  44. </sect2>
  45. <sect2 id="zend.soap.wsdl.addmessage">
  46. <title>addMessage()メソッド</title>
  47. <para>
  48. <methodname>addMessage($name, $parts)</methodname>メソッドは、新しいメッセージの説明をWSDL文書に加えます。
  49. (/definitions/message 要素)
  50. </para>
  51. <para>
  52. <classname>Zend_Soap_Server</classname>および<classname>Zend_Soap_Client</classname>の機能に関して、
  53. 各々のメッセージはメソッドと対応します。
  54. </para>
  55. <para>
  56. <code>$name</code>パラメータはメッセージの名前を示します。
  57. </para>
  58. <para>
  59. <code>$parts</code>パラメータは<acronym>SOAP</acronym>呼び出しパラメータを表すメッセージ部分の配列です。
  60. それは連想配列です: 'part name' (<acronym>SOAP</acronym>呼び出しパラメータ名) =&gt; 'part type'.
  61. </para>
  62. <para>
  63. 型マッピングの管理は<methodname>addTypes()</methodname>や<methodname>addTypes()</methodname>、
  64. および<methodname>addComplexType()</methodname>メソッド(下記参照)を用いて実行されます。
  65. </para>
  66. <note>
  67. <para>
  68. メッセージ部分は 'element' または 'type' 属性を型決定のために使います。
  69. (<ulink url="http://www.w3.org/TR/wsdl#_messages"/>をご覧ください).
  70. </para>
  71. <para>
  72. 'element' 属性は、データ型定義の対応する要素を参照しなければなりません。
  73. 'type' 属性は、対応するcomplexType項目を参照します。
  74. </para>
  75. <para>
  76. 標準XSD型のすべてで 'element' および 'complexType' 定義の両方があります。
  77. (<ulink url="http://schemas.xmlsoap.org/soap/encoding/"/>参照)
  78. </para>
  79. <para>
  80. <methodname>Zend_Soap_Wsdl::addComplexType()</methodname>メソッドを用いて追加されるであろう、
  81. 標準ではない型のすべてがWSDL文書の '/definitions/types/schema/' セクションの 'complexType' ノードで記述されます。
  82. </para>
  83. <para>
  84. そして<methodname>addMessage()</methodname>メソッドは型を表現するために、
  85. 常に 'type' 属性を使います。
  86. </para>
  87. </note>
  88. </sect2>
  89. <sect2 id="zend.soap.wsdl.add_port_type">
  90. <title>addPortType()メソッド</title>
  91. <para>
  92. <methodname>addPortType($name)</methodname>メソッドは指定されたポートタイプ名で
  93. WSDL文書 (/definitions/portType) に新規のポートタイプを追加します。
  94. </para>
  95. <para>
  96. <classname>Zend_Soap_Server</classname>の実装に関して定義されるウェブサービスメソッドのセットと結びつきます。
  97. </para>
  98. <para>
  99. 詳しくは<ulink url="http://www.w3.org/TR/wsdl#_porttypes"/>をご覧ください。
  100. </para>
  101. </sect2>
  102. <sect2 id="zend.soap.wsdl.add_port_operation">
  103. <title>addPortOperation()メソッド</title>
  104. <para>
  105. <methodname>addPortOperation($portType, $name, $input = false, $output = false, $fault = false)</methodname>
  106. メソッドは、新しいポート・オペレーションをWSDL文書 (/definitions/portType/operation) の
  107. 指定されたポート・タイプに加えます。
  108. </para>
  109. <para>
  110. 各々のポート・オペレーションは<classname>Zend_Soap_Server</classname>実装では、
  111. クラス・メソッド(ウェブサービスがクラスに基づくならば)
  112. または関数(ウェブサービスがメソッドセットに基づくならば)に対応します。
  113. </para>
  114. <para>
  115. それも、指定されたパラメータ、<code>$input</code>や<code>$output</code>および<code>$fault</code>に従って、
  116. 対応するポート・オペレーション・メッセージを加えます。
  117. <note>
  118. <para>
  119. <classname>Zend_Soap_Server</classname>クラスに基づいてサービスを記述するために、
  120. <classname>Zend_Soap_Server</classname>コンポーネントは各々のポート・オペレーションのために2つのメッセージを生成します:
  121. <itemizedlist>
  122. <listitem>
  123. <para>
  124. <code>$methodName . 'Request'</code>という名前で入力メッセージ。
  125. </para>
  126. </listitem>
  127. <listitem>
  128. <para>
  129. <code>$methodName . 'Response'</code>という名前で出力メッセージ。
  130. </para>
  131. </listitem>
  132. </itemizedlist>
  133. </para>
  134. </note>
  135. </para>
  136. <para>
  137. 詳しくは<ulink url="http://www.w3.org/TR/wsdl#_request-response"/>をご覧ください。
  138. </para>
  139. </sect2>
  140. <sect2 id="zend.soap.wsdl.add_binding">
  141. <title>addBinding()メソッド</title>
  142. <para>
  143. <methodname>addBinding($name, $portType)</methodname>メソッドは、新しいバインディングをWSDL文書 (/definitions/binding) に加えます。
  144. </para>
  145. <para>
  146. 'binding' WSDL文書ノードでは、
  147. メッセージ形式と特定のportTypeによって定義されるオペレーションとメッセージに関するプロトコル詳細を定義します。
  148. (<ulink url="http://www.w3.org/TR/wsdl#_bindings"/>をご覧ください)
  149. </para>
  150. <para>
  151. メソッドはバインディング・ノードをつくって、それを返します。
  152. それから、実際のデータで満たすために使われるかもしれません。
  153. </para>
  154. <para>
  155. <classname>Zend_Soap_Server</classname>の実装ではWSDL文書の 'binding' 要素のために<code>$serviceName . 'Binding'</code> の名前が使われます。
  156. </para>
  157. </sect2>
  158. <sect2 id="zend.soap.wsdl.add_binding_operation">
  159. <title>addBindingOperation()メソッド</title>
  160. <para>
  161. <methodname>addBindingOperation($binding, $name, $input = false, $output = false, $fault = false)</methodname>
  162. メソッドはバインディング要素 (/definitions/binding/operation) に指定された名前で操作を追加します。
  163. </para>
  164. <para>
  165. 指定されたパラメータに従って、
  166. 入力・出力・false値を持つ 'operation' 要素を加えるために、
  167. 入力(<code>$binding</code>パラメータ)として<methodname>addBinding()</methodname>によって返される
  168. <code>XML_Tree_Node</code>オブジェクトをそのメソッドは取得します。
  169. </para>
  170. <para>
  171. <classname>Zend_Soap_Server</classname>の実装で、 'soap:body' 要素を
  172. '&lt;soap:body use="encoded" encodingStyle="http://schemas.xmlsoap.org/soap/encoding/"/&gt;
  173. として定義している入出力エントリで、
  174. ウェブサービス・メソッドごとに対応するバインディング・エントリを加えます。
  175. </para>
  176. <para>
  177. 詳しくは<ulink url="http://www.w3.org/TR/wsdl#_bindings"/>をご覧ください。
  178. </para>
  179. </sect2>
  180. <sect2 id="zend.soap.wsdl.add_soap_binding">
  181. <title>addSoapBinding()メソッド</title>
  182. <para>
  183. <methodname>addSoapBinding($binding, $style = 'document', $transport = 'http://schemas.xmlsoap.org/soap/http')</methodname>
  184. メソッドは、指定されたスタイルとトランスポート(<classname>Zend_Soap_Server</classname>の実装では、<acronym>HTTP</acronym>についてRPCスタイルを使用します)で
  185. <acronym>SOAP</acronym>バインディング項目 ('soap:binding') をバインディング要素(それは、あるポートタイプにすでにリンクされます)に追加します。
  186. </para>
  187. <para>
  188. '/definitions/binding/soap:binding' 要素は、
  189. バインディングが<acronym>SOAP</acronym>プロトコル形式に束縛されることを示すのに用いられます。
  190. </para>
  191. <para>
  192. 詳しくは<ulink url="http://www.w3.org/TR/wsdl#_bindings"/>をご覧ください。
  193. </para>
  194. </sect2>
  195. <sect2 id="zend.soap.wsdl.add_soap_operation">
  196. <title>addSoapOperation()メソッド</title>
  197. <para>
  198. <methodname>addSoapOperation($binding, $soap_action)</methodname>メソッドは、
  199. <acronym>SOAP</acronym>操作項目 ('soap:operation') を指定されたアクションでバインディング要素に加えます。
  200. 'soap:operation' 要素の 'style' 属性は、(RPC指向か文書指向の)プログラミング・モデルが
  201. <methodname>addSoapBinding()</methodname>メソッドを使用しているかもしれないので使われません。
  202. </para>
  203. <para>
  204. '/definitions/binding/soap:operation' 要素の 'soapAction' 属性は、
  205. この操作のためにSOAPActionヘッダの値を指定します。
  206. この属性は<acronym>HTTP</acronym>を通じた<acronym>SOAP</acronym>で必須です。
  207. 他のトランスポートのために指定しては<emphasis>いけません</emphasis>。
  208. </para>
  209. <para>
  210. <classname>Zend_Soap_Server</classname>の実装では、<acronym>SOAP</acronym>操作アクション名のために
  211. <code>$serviceUri . '#' . $methodName</code>を使います。
  212. </para>
  213. <para>
  214. 詳しくは<ulink url="http://www.w3.org/TR/wsdl#_soap:operation"/>をご覧ください。
  215. </para>
  216. </sect2>
  217. <sect2 id="zend.soap.wsdl.add_service">
  218. <title>addService()メソッド</title>
  219. <para>
  220. <methodname>addService($name, $port_name, $binding, $location)</methodname>メソッドは
  221. 指定したウェブサービス名やポートタイプ及びバインディング、ロケーションとともに
  222. WSDL文書に '/definitions/service' 要素を追加します。
  223. </para>
  224. <para>
  225. WSDL 1.1では、サービスごとにいくつかのポートタイプ(操作のセット)を持つことができます。
  226. この能力は<classname>Zend_Soap_Server</classname>の実装では使われず、
  227. <classname>Zend_Soap_Wsdl</classname>クラスでサポートされません。
  228. </para>
  229. <para>
  230. <classname>Zend_Soap_Server</classname>の実装に使用します:
  231. <itemizedlist>
  232. <listitem>
  233. <para>
  234. ウェブサービス名として<code>$name . 'Service'</code>
  235. </para>
  236. </listitem>
  237. <listitem>
  238. <para>
  239. ポートタイプ名として<code>$name . 'Port'</code>
  240. </para>
  241. </listitem>
  242. <listitem>
  243. <para>
  244. バインディング名として<code>'tns:' . $name . 'Binding'</code>
  245. <footnote>
  246. <para>
  247. <code>'tns:' namespace</code>はスクリプトの<acronym>URI</acronym>
  248. (<code>'http://' .$_SERVER['HTTP_HOST'] . $_SERVER['SCRIPT_NAME']</code>)
  249. として定義されます。
  250. </para>
  251. </footnote>
  252. </para>
  253. </listitem>
  254. <listitem>
  255. <para>
  256. クラスを使うウェブサービスの定義のためのサービス<acronym>URI</acronym>としてスクリプトの<acronym>URI</acronym>
  257. <footnote><para><code>'http://' .$_SERVER['HTTP_HOST'] . $_SERVER['SCRIPT_NAME']</code></para></footnote>
  258. </para>
  259. </listitem>
  260. </itemizedlist>
  261. <code>$name</code>がクラスを使うウェブサービス定義モードのためのクラス名と
  262. 関数のセットを使うウェブサービス定義モードのためのスクリプト名前であるところ。
  263. </para>
  264. <para>
  265. 詳しくは<ulink url="http://www.w3.org/TR/wsdl#_services"/>をご覧ください。
  266. </para>
  267. </sect2>
  268. <sect2 id="zend.soap.wsdl.types">
  269. <title>型のマッピング</title>
  270. <para>
  271. <classname>Zend_Soap</classname> WSDLアクセッサの実装では、<acronym>PHP</acronym>と<acronym>SOAP</acronym>型の間で以下の型マッピングを使用します:
  272. <itemizedlist>
  273. <listitem>
  274. <para><acronym>PHP</acronym>文字列 &lt;-&gt; <code>xsd:string</code></para>
  275. </listitem>
  276. <listitem>
  277. <para><acronym>PHP</acronym> integer &lt;-&gt; <code>xsd:int</code></para>
  278. </listitem>
  279. <listitem>
  280. <para><acronym>PHP</acronym> floatおよびdouble値 &lt;-&gt; <code>xsd:float</code></para>
  281. </listitem>
  282. <listitem>
  283. <para><acronym>PHP</acronym>ブール値 &lt;-&gt; <code>xsd:boolean</code></para>
  284. </listitem>
  285. <listitem>
  286. <para><acronym>PHP</acronym>配列 &lt;-&gt; <code>soap-enc:Array</code></para>
  287. </listitem>
  288. <listitem>
  289. <para><acronym>PHP</acronym>オブジェクト &lt;-&gt; <code>xsd:struct</code></para>
  290. </listitem>
  291. <listitem>
  292. <para>
  293. <acronym>PHP</acronym>クラス &lt;-&gt; 複雑な型のストラテジーに基づいた (<link linkend="zend.soap.wsdl.types.add_complex">この節</link>を参照)
  294. <footnote>
  295. <para>
  296. デフォルトで、<classname>Zend_Soap_Wsdl</classname>は複雑な型のための検出アルゴリズムとして
  297. <classname>Zend_Soap_Wsdl_Strategy_DefaultComplexType</classname>クラスで生成されます。
  298. AutoDiscoverコンストラクタの最初のパラメータは、
  299. <classname>Zend_Soap_Wsdl_Strategy_Interface</classname>を実装した、
  300. どんな複雑な型ストラテジーでも、クラスの名前を持つ文字列でもとります。
  301. <code>$extractComplexType</code>との後方互換性のために、
  302. ブール変数は、以下の方法で解析されます:
  303. もし <constant>TRUE</constant> なら、<classname>Zend_Soap_Wsdl_Strategy_DefaultComplexType</classname>、
  304. もし <constant>FALSE</constant> なら、<classname>Zend_Soap_Wsdl_Strategy_AnyType</classname>。
  305. </para>
  306. </footnote>
  307. </para>
  308. </listitem>
  309. <listitem>
  310. <para><acronym>PHP</acronym> void &lt;-&gt; 空の型</para>
  311. </listitem>
  312. <listitem>
  313. <para>なんらかの理由でこれらの型のいずれとも型が一致しなければ、<code>xsd:anyType</code>が使われます。</para>
  314. </listitem>
  315. </itemizedlist>
  316. <code>xsd:</code> が "http://www.w3.org/2001/XMLSchema" ネームスペースであるところでは、
  317. <code>soap-enc:</code> は "http://schemas.xmlsoap.org/soap/encoding/" ネームスペースで、
  318. <code>tns:</code> はサービスのための "target namespace" です。
  319. </para>
  320. <sect3 id="zend.soap.wsdl.types.retrieve">
  321. <title>型情報の取得</title>
  322. <para>
  323. <methodname>getType($type)</methodname>メソッドは、指定された <acronym>PHP</acronym> 型をマップするために用いられるかもしれません:
  324. </para>
  325. <programlisting language="php"><![CDATA[
  326. ...
  327. $wsdl = new Zend_Soap_Wsdl('My_Web_Service', $myWebServiceUri);
  328. ...
  329. $soapIntType = $wsdl->getType('int');
  330. ...
  331. class MyClass {
  332. ...
  333. }
  334. ...
  335. $soapMyClassType = $wsdl->getType('MyClass');
  336. ]]></programlisting>
  337. </sect3>
  338. <sect3 id="zend.soap.wsdl.types.add_complex">
  339. <title>複雑な型の情報を追加する</title>
  340. <para>
  341. <methodname>addComplexType($type)</methodname>メソッドは、
  342. 複雑な型(<acronym>PHP</acronym>クラス)をWSDL文書に追加するために使われます。
  343. </para>
  344. <para>
  345. メソッド・パラメータの対応する複雑な型を追加するか、型を返すために、
  346. <methodname>getType()</methodname>メソッドによってそれは自動的に使われます。
  347. </para>
  348. <para>
  349. その検出とビルドのアルゴリズムは、複雑な型に対して現在実装中の検出ストラテジーに基づきます。
  350. 文字列でのクラス名指定、
  351. または、コンストラクタの第3パラメータとして<classname>Zend_Soap_Wsdl_Strategy_Interface</classname>を実装したインスタンス、
  352. または、<classname>Zend_Soap_Wsdl</classname>の<code>setComplexTypeStrategy($strategy)</code>関数の利用のいずれかにより、
  353. 検出ストラテジーを設定できます。
  354. 以下の検出ストラテジーが、現在存在します:
  355. </para>
  356. <itemizedlist>
  357. <listitem>
  358. <para>クラス<classname>Zend_Soap_Wsdl_Strategy_DefaultComplexType</classname>:
  359. デフォルトで許可されます(第3のコンストラクタ・パラメータが設定されないとき)。
  360. クラス型の public 属性項目を反復して、
  361. 複雑なオブジェクト型のサブタイプとして登録します。</para>
  362. </listitem>
  363. <listitem>
  364. <para>クラス<classname>Zend_Soap_Wsdl_Strategy_AnyType</classname>:
  365. 単純なXSD型 xsd:anyType に、すべての複雑な型を投げます。
  366. 複雑な型検出のこのショートカットが
  367. <acronym>PHP</acronym>のような型検査の弱い言語により、うまく取り扱われるかどうか注意してください。</para>
  368. </listitem>
  369. <listitem>
  370. <para>クラス<classname>Zend_Soap_Wsdl_Strategy_ArrayOfTypeSequence</classname>:
  371. このストラテジーにより、以下のようにタイプの戻りパラメータを指定できます:
  372. <code>int[]</code>または<code>string[]</code>.
  373. Zend Framework バージョン 1.9 以降、
  374. それは単純な<acronym>PHP</acronym>型(例えばint)、文字列、ブール値、floatなどを取り扱えるばかりではなく、
  375. オブジェクトおよびオブジェクトの配列も指定できます。</para>
  376. </listitem>
  377. <listitem>
  378. <para>クラス<classname>Zend_Soap_Wsdl_Strategy_ArrayOfTypeComplex</classname>:
  379. このストラテジーにより、非常に複雑な多数のオブジェクトを見つけることができます。
  380. オブジェクト型は<classname>Zend_Soap_Wsdl_Strategy_DefaultComplexType</classname>に基づいて
  381. 検出されます。配列はその定義の周囲を包まれます。</para>
  382. </listitem>
  383. <listitem>
  384. <para>クラス<classname>Zend_Soap_Wsdl_Strategy_Composite</classname>:
  385. このストラテジーは、<methodname>connectTypeToStrategy($type, $strategy)</methodname>メソッドを通じて
  386. 希望するストラテジーに<acronym>PHP</acronym>の複雑な型(クラス名)を接続することによって、
  387. すべてのストラテジーを結合できます。
  388. 完全なタイプマップを、<code>$type</code> -> <code>$strategy</code> のペアを持つ配列として
  389. コンストラクタに与えられます。
  390. もし未知の型の追加が必要であれば、第2パラメータで使われるデフォルト・ストラテジーを指定します。
  391. このパラメータのデフォルトは、<classname>Zend_Soap_Wsdl_Strategy_DefaultComplexType</classname>です。</para>
  392. </listitem>
  393. </itemizedlist>
  394. <para>
  395. <methodname>addComplexType()</methodname>メソッドは、指定された<acronym>PHP</acronym>クラスの名前で、
  396. 記述された複雑な型ごとに '/definitions/types/xsd:schema/xsd:complexType' 要素を生成します。
  397. </para>
  398. <para>
  399. クラスのプロパティは、プロパティをWSDL記述にインクルードしておくために、記述された<acronym>PHP</acronym>型でdocblock部を持って<emphasis>いなければなりません</emphasis>。
  400. </para>
  401. <para>
  402. <methodname>addComplexType()</methodname>は型がWSDL文書の型セクションの範囲内ですでに記述されるかどうか調べます。
  403. </para>
  404. <para>
  405. このメソッドが型定義部で2回以上再帰で呼ばれると、それは重複を防ぎます。
  406. </para>
  407. <para>
  408. 詳しくは<ulink url="http://www.w3.org/TR/wsdl#_types"/>をご覧ください。
  409. </para>
  410. </sect3>
  411. </sect2>
  412. <sect2 id="zend.soap.wsdl.add_documentation">
  413. <title>addDocumentation()メソッド</title>
  414. <para>
  415. <methodname>addDocumentation($input_node, $documentation)</methodname>メソッドは、
  416. オプションの 'wsdl:document' 要素を用いて人間の読める文書を追加します。
  417. </para>
  418. <para>
  419. '/definitions/binding/soap:binding' 要素は、
  420. バインディングが<acronym>SOAP</acronym>プロトコル構成にバインドされることを示すために使われます。
  421. </para>
  422. <para>
  423. 詳しくは<ulink url="http://www.w3.org/TR/wsdl#_documentation"/>をご覧ください。
  424. </para>
  425. </sect2>
  426. <sect2 id="zend.soap.wsdl.retrieve">
  427. <title>確定したWSDL文書を取得</title>
  428. <para>
  429. <methodname>toXML()</methodname>や<methodname>toDomDocument()</methodname>および<methodname>dump($filename = false)</methodname>メソッドは、
  430. WSDL文書を<acronym>XML</acronym>やDOMの構造もしくはファイルとして取得するために使われるかもしれません。
  431. </para>
  432. </sect2>
  433. </sect1>