Zend_Http_Client-Migration.xml 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 17175 -->
  4. <sect1 id="zend.http.client.migration">
  5. <title>前バージョンからの移行</title>
  6. <para>
  7. <classname>Zend_Http_Client</classname>の外部 <acronym>API</acronym> は Zend Framework の 1.x ブランチと整合したままですが、
  8. <classname>Zend_Http_Client</classname>とその関連したクラスの内部構造に若干の変化がもたらされました。
  9. </para>
  10. <para>
  11. これらの変化は、<classname>Zend_Http_Client</classname>を用いたコードに影響すべきではありません
  12. しかし、オーバーロードするか、または拡張する<acronym>PHP</acronym>クラスに影響するかもしれません。
  13. アプリケーションが<classname>Zend_Http_Client</classname>をサブクラスとするなら、
  14. Zend Frameworkをアップグレードする前に以下の変化に目を通すことを大いに勧めます。
  15. </para>
  16. <sect2 id="zend.http.client.migration.tozf19">
  17. <title>1.8 以前から 1.9 以降への移行</title>
  18. <sect3 id="zend.http.client.migration.tozf19.fileuploadsarray">
  19. <title>内部のアップロードされたファイル情報ストレージに変更</title>
  20. <para>
  21. Zend Framework のバージョン 1.9 では、
  22. アップロードされるファイルに関する情報を
  23. <classname>Zend_Http_Client</classname>が内部的に格納し、
  24. <methodname>Zend_Http_Client::setFileUpload()</methodname>メソッドを用いてセットする
  25. 方法で変化がありました。
  26. </para>
  27. <para>
  28. 複数のファイルを同じフォーム名で
  29. ファイルの配列としてアップロードできるように
  30. この変化が取り入れられました。
  31. この問題に関するより多くの情報は、
  32. <ulink url="http://framework.zend.com/issues/browse/ZF-5744">このバグ・レポート</ulink>
  33. で見つけることができます。
  34. </para>
  35. <example id="zend.http.client.migration.tozf19.fileuploadsarray.example">
  36. <title>アップロードされたファイル情報の内部ストレージ</title>
  37. <programlisting language="php"><![CDATA[
  38. // ファイル2つを同じフォーム要素名でファイルの配列としてアップロード
  39. $client = new Zend_Http_Client();
  40. $client->setFileUpload('file1.txt',
  41. 'userfile[]',
  42. 'some raw data',
  43. 'text/plain');
  44. $client->setFileUpload('file2.txt',
  45. 'userfile[]',
  46. 'some other data',
  47. 'application/octet-stream');
  48. // Zend Framework の 1.8 以前では、
  49. // protected メンバー $client->files の値はこうです:
  50. // $client->files = array(
  51. // 'userfile[]' => array('file2.txt',
  52. 'application/octet-stream',
  53. 'some other data')
  54. // );
  55. // Zend Framework の 1.9 以降では、$client->files の値はこうです:
  56. // $client->files = array(
  57. // array(
  58. // 'formname' => 'userfile[]',
  59. // 'filename' => 'file1.txt,
  60. // 'ctype' => 'text/plain',
  61. // 'data' => 'some raw data'
  62. // ),
  63. // array(
  64. // 'formname' => 'userfile[]',
  65. // 'filename' => 'file2.txt',
  66. // 'formname' => 'application/octet-stream',
  67. // 'formname' => 'some other data'
  68. // )
  69. // );
  70. ]]></programlisting>
  71. </example>
  72. <para>
  73. ご覧の通り、この変化は1つ以上のファイルで同じフォーム要素名を使えるようにします。
  74. しかし、それは微妙な下位互換性変化を取り入れるので、そのように注意するべきです。
  75. </para>
  76. </sect3>
  77. <sect3 id="zend.http.client.migration.tozf19.getparamsrecursize">
  78. <title>Zend_Http_Client::_getParametersRecursive() の廃止</title>
  79. <para>
  80. バージョン1.9から始まりますが、
  81. protected メソッド <methodname>_getParametersRecursive()</methodname> はもはや
  82. <classname>Zend_Http_Client</classname> に使われず、廃止されます。
  83. それを使うと、E_NOTICE メッセージが<acronym>PHP</acronym>によって発生する原因になります。
  84. </para>
  85. <para>
  86. <classname>Zend_Http_Client</classname>をサブクラスとして、このメソッドを呼ぶなら、
  87. その代わりに <methodname>Zend_Http_Client::_flattenParametersArray()</methodname>
  88. static メソッドを使用することに目を向けるべきです。
  89. </para>
  90. <para>
  91. また、この<classname>_getParametersRecursive</classname>は protected メソッドなので、
  92. この変化は<classname>Zend_Http_Client</classname>をサブクラスとするユーザーに
  93. 影響を及ぼすだけです。
  94. </para>
  95. </sect3>
  96. </sect2>
  97. </sect1>