Zend_File_Transfer-Migration.xml 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 17685 -->
  4. <sect1 id="zend.file.transfer.migration">
  5. <title>以前のバージョンからの移行</title>
  6. <para>
  7. <classname>Zend_File_Transfer</classname> の <acronym>API</acronym> は日々変わっています。
  8. <classname>Zend_File_Transfer</classname> やそのサブコンポーネントを
  9. 初期のバージョンから使っている方は、以下のガイドラインに従ってスクリプトを変更し、
  10. 新しい <acronym>API</acronym> にあわせましょう。
  11. </para>
  12. <sect2 id="zend.file.transfer.migration.fromonenineonetooneten">
  13. <title>1.9 から 1.10 以降への移行</title>
  14. <sect3 id="zend.file.transfer.migration.fromonenineonetooneten.mimetype">
  15. <title>MimeType の検証</title>
  16. <para>
  17. セキュリティ上の理由から、
  18. <classname>MimeType</classname>、<classname>ExcludeMimeType</classname>、
  19. <classname>IsCompressed</classname> および <classname>IsImage</classname>
  20. バリデータにおけるデフォルトのフォールバック機能を無効にしました。
  21. つまり、<emphasis>fileInfo</emphasis> 拡張モジュールあるいは
  22. <emphasis>magicMime</emphasis> 拡張モジュールがなければ、
  23. 検証が常に失敗するようになるということです。
  24. </para>
  25. <para>
  26. ユーザ側から渡された <acronym>HTTP</acronym> フィールドを使用して入力を検証する必要がある場合は、
  27. <methodname>enableHeaderCheck()</methodname> メソッドを使用すればこの機能を有効にできます。
  28. </para>
  29. <note>
  30. <title>セキュリティに関するヒント</title>
  31. <para>
  32. ユーザ側から渡された <acronym>HTTP</acronym>
  33. フィールドに依存するのはセキュリティ上のリスクとなることに注意しましょう。
  34. これは簡単に改ざんすることができ、悪意のあるファイルを受け取る可能性があります。
  35. ユーザ側から渡された <acronym>HTTP</acronym> フィールドを使用して入力を検証する必要がある場合は、
  36. <methodname>enableHeaderCheck()</methodname> メソッドを使用すればこの機能を有効にできます。
  37. </para>
  38. </note>
  39. <example id="zend.file.transfer.migration.fromonenineonetooneten.example">
  40. <title>HTTP フィールドの使用を許可する</title>
  41. <programlisting language="php"><![CDATA[
  42. // 初期化時に
  43. $valid = new Zend_File_Transfer_Adapter_Http(array('headerCheck' => true);
  44. // あるいは後から
  45. $valid->enableHeaderCheck();
  46. ]]></programlisting>
  47. </example>
  48. </sect3>
  49. </sect2>
  50. <sect2 id="zend.file.transfer.migration.fromonesixtooneseven">
  51. <title>1.6 から 1.7 以降への移行</title>
  52. <sect3 id="zend.file.transfer.migration.fromonesixtooneseven.validators">
  53. <title>フィルタやバリデータを使用する際の変更点</title>
  54. <para>
  55. <classname>Zend_File_Transfer</classname> のバリデータが
  56. <classname>Zend_Config</classname> と組み合わせて使えないという指摘がありました。
  57. 名前つき配列を使っていなかったからです。
  58. </para>
  59. <para>
  60. そこで、<classname>Zend_File_Transfer</classname> 用のすべてのフィルタとバリデータを作り直しました。
  61. 古い構文でも動作しますがこれは非推奨となり、
  62. 設定せずに実行すると <acronym>PHP</acronym> の notice が発生するようになります。
  63. </para>
  64. <para>
  65. 次のリストは、パラメータの使用法に関する変更点をまとめたものです。
  66. </para>
  67. <sect4 id="zend.file.transfer.migration.fromonesixtooneseven.validators.rename">
  68. <title>Rename フィルタ</title>
  69. <itemizedlist>
  70. <listitem><para>
  71. 古い形式の <acronym>API</acronym>: <classname>Zend_Filter_File_Rename($oldfile, $newfile, $overwrite)</classname>
  72. </para></listitem>
  73. <listitem><para>
  74. 新しい形式の <acronym>API</acronym>: <methodname>Zend_Filter_File_Rename($options)</methodname>
  75. $options には次の配列キーを使えます。
  76. <emphasis>source</emphasis> ($oldfile と同等)、
  77. <emphasis>target</emphasis> ($newfile と同等)、
  78. <emphasis>overwrite</emphasis> ($overwrite と同等)
  79. </para></listitem>
  80. </itemizedlist>
  81. <example id="zend.file.transfer.migration.fromonesixonetooneseven.validators.rename.example">
  82. <title>rename フィルタの 1.6 から 1.7 での変更点</title>
  83. <programlisting language="php"><![CDATA[
  84. // 1.6 の例
  85. $upload = new Zend_File_Transfer_Adapter_Http();
  86. $upload->addFilter('Rename',
  87. array('/path/to/oldfile', '/path/to/newfile', true));
  88. // 1.7 の例
  89. $upload = new Zend_File_Transfer_Adapter_Http();
  90. $upload->addFilter('Rename',
  91. array('source' => '/path/to/oldfile',
  92. 'target' => '/path/to/newfile',
  93. 'overwrite' => true));
  94. ]]></programlisting>
  95. </example>
  96. </sect4>
  97. <sect4 id="zend.file.transfer.migration.fromonesixtooneseven.validators.count">
  98. <title>Count バリデータ</title>
  99. <itemizedlist>
  100. <listitem><para>
  101. 古い形式の <acronym>API</acronym>: <methodname>Zend_Validate_File_Count($min, $max)</methodname>
  102. </para></listitem>
  103. <listitem><para>
  104. 新しい形式の <acronym>API</acronym>: <methodname>Zend_Validate_File_Count($options)</methodname>
  105. $options には次の配列キーを使えます。
  106. <emphasis>min</emphasis> ($min と同等)、
  107. <emphasis>max</emphasis> ($max と同等)
  108. </para></listitem>
  109. </itemizedlist>
  110. <example id="zend.file.transfer.migration.fromonesixonetooneseven.validators.count.example">
  111. <title>count バリデータの 1.6 から 1.7 での変更点</title>
  112. <programlisting language="php"><![CDATA[
  113. // 1.6 の例
  114. $upload = new Zend_File_Transfer_Adapter_Http();
  115. $upload->addValidator('Count',
  116. array(2, 3));
  117. // 1.7 の例
  118. $upload = new Zend_File_Transfer_Adapter_Http();
  119. $upload->addValidator('Count',
  120. false,
  121. array('min' => 2,
  122. 'max' => 3));
  123. ]]></programlisting>
  124. </example>
  125. </sect4>
  126. <sect4 id="zend.file.transfer.migration.fromonesixtooneseven.validators.extension">
  127. <title>Extension バリデータ</title>
  128. <itemizedlist>
  129. <listitem><para>
  130. 古い形式の <acronym>API</acronym>: <classname>Zend_Validate_File_Extension($extension, $case)</classname>
  131. </para></listitem>
  132. <listitem><para>
  133. 新しい形式の <acronym>API</acronym>: <methodname>Zend_Validate_File_Extension($options)</methodname>
  134. $options には次の配列キーを使えます。
  135. <emphasis>*</emphasis> ($extension と同等、任意の他のキーを使用可能)、
  136. <emphasis>case</emphasis> ($case と同等)
  137. </para></listitem>
  138. </itemizedlist>
  139. <example id="zend.file.transfer.migration.fromonesixonetooneseven.validators.extension.example">
  140. <title>extension バリデータの 1.6 から 1.7 での変更点</title>
  141. <programlisting language="php"><![CDATA[
  142. // 1.6 の例
  143. $upload = new Zend_File_Transfer_Adapter_Http();
  144. $upload->addValidator('Extension',
  145. array('jpg,gif,bmp', true));
  146. // 1.7 の例
  147. $upload = new Zend_File_Transfer_Adapter_Http();
  148. $upload->addValidator('Extension',
  149. false,
  150. array('extension1' => 'jpg,gif,bmp',
  151. 'case' => true));
  152. ]]></programlisting>
  153. </example>
  154. </sect4>
  155. <sect4 id="zend.file.transfer.migration.fromonesixtooneseven.validators.filessize">
  156. <title>FilesSize バリデータ</title>
  157. <itemizedlist>
  158. <listitem><para>
  159. 古い形式の <acronym>API</acronym>: <classname>Zend_Validate_File_FilesSize($min, $max, $bytestring)</classname>
  160. </para></listitem>
  161. <listitem><para>
  162. 新しい形式の <acronym>API</acronym>: <methodname>Zend_Validate_File_FilesSize($options)</methodname>
  163. $options には次の配列キーを使えます。
  164. <emphasis>min</emphasis> ($min と同等)、
  165. <emphasis>max</emphasis> ($max と同等)、
  166. <emphasis>bytestring</emphasis> ($bytestring と同等)
  167. </para></listitem>
  168. </itemizedlist>
  169. <para>
  170. さらに <methodname>useByteString()</methodname> メソッドのシグネチャも変わりました。
  171. このメソッドの使用法は、
  172. そのバリデータが生成するメッセージでバイト文字列を使うことを想定しているかどうかを調べるだけになりました。
  173. フラグの値を設定するには
  174. <methodname>setUseByteString()</methodname> メソッドを使用します。
  175. </para>
  176. <example id="zend.file.transfer.migration.fromonesixonetooneseven.validators.filessize.example">
  177. <title>filessize バリデータの 1.6 から 1.7 での変更点</title>
  178. <programlisting language="php"><![CDATA[
  179. // 1.6 の例
  180. $upload = new Zend_File_Transfer_Adapter_Http();
  181. $upload->addValidator('FilesSize',
  182. array(100, 10000, true));
  183. // 1.7 の例
  184. $upload = new Zend_File_Transfer_Adapter_Http();
  185. $upload->addValidator('FilesSize',
  186. false,
  187. array('min' => 100,
  188. 'max' => 10000,
  189. 'bytestring' => true));
  190. // 1.6 の例
  191. $upload->useByteString(true); // set flag
  192. // 1.7 の例
  193. $upload->setUseByteSting(true); // set flag
  194. ]]></programlisting>
  195. </example>
  196. </sect4>
  197. <sect4 id="zend.file.transfer.migration.fromonesixtooneseven.validators.hash">
  198. <title>Hash バリデータ</title>
  199. <itemizedlist>
  200. <listitem><para>
  201. 古い形式の <acronym>API</acronym>: <classname>Zend_Validate_File_Hash($hash, $algorithm)</classname>
  202. </para></listitem>
  203. <listitem><para>
  204. 新しい形式の <acronym>API</acronym>: <methodname>Zend_Validate_File_Hash($options)</methodname>
  205. $options には次の配列キーを使えます。
  206. <emphasis>*</emphasis> ($hash と同等、任意の他のキーを使用可能)、
  207. <emphasis>algorithm</emphasis> ($algorithm と同等)、
  208. </para></listitem>
  209. </itemizedlist>
  210. <example id="zend.file.transfer.migration.fromonesixonetooneseven.validators.hash.example">
  211. <title>hash バリデータの 1.6 から 1.7 での変更点</title>
  212. <programlisting language="php"><![CDATA[
  213. // 1.6 の例
  214. $upload = new Zend_File_Transfer_Adapter_Http();
  215. $upload->addValidator('Hash',
  216. array('12345', 'md5'));
  217. // 1.7 の例
  218. $upload = new Zend_File_Transfer_Adapter_Http();
  219. $upload->addValidator('Hash',
  220. false,
  221. array('hash1' => '12345',
  222. 'algorithm' => 'md5'));
  223. ]]></programlisting>
  224. </example>
  225. </sect4>
  226. <sect4 id="zend.file.transfer.migration.fromonesixtooneseven.validators.imagesize">
  227. <title>ImageSize バリデータ</title>
  228. <itemizedlist>
  229. <listitem><para>
  230. 古い形式の <acronym>API</acronym>: <classname>Zend_Validate_File_ImageSize($minwidth, $minheight, $maxwidth, $maxheight)</classname>
  231. </para></listitem>
  232. <listitem><para>
  233. 新しい形式の <acronym>API</acronym>: <methodname>Zend_Validate_File_FilesSize($options)</methodname>
  234. $options には次の配列キーを使えます。
  235. <emphasis>minwidth</emphasis> ($minwidth と同等)、
  236. <emphasis>maxwidth</emphasis> ($maxwidth と同等)、
  237. <emphasis>minheight</emphasis> ($minheight と同等)、
  238. <emphasis>maxheight</emphasis> ($maxheight と同等)
  239. </para></listitem>
  240. </itemizedlist>
  241. <example id="zend.file.transfer.migration.fromonesixonetooneseven.validators.imagesize.example">
  242. <title>imagesize バリデータの 1.6 から 1.7 での変更点</title>
  243. <programlisting language="php"><![CDATA[
  244. // 1.6 の例
  245. $upload = new Zend_File_Transfer_Adapter_Http();
  246. $upload->addValidator('ImageSize',
  247. array(10, 10, 100, 100));
  248. // 1.7 の例
  249. $upload = new Zend_File_Transfer_Adapter_Http();
  250. $upload->addValidator('ImageSize',
  251. false,
  252. array('minwidth' => 10,
  253. 'minheight' => 10,
  254. 'maxwidth' => 100,
  255. 'maxheight' => 100));
  256. ]]></programlisting>
  257. </example>
  258. </sect4>
  259. <sect4 id="zend.file.transfer.migration.fromonesixtooneseven.validators.size">
  260. <title>Size バリデータ</title>
  261. <itemizedlist>
  262. <listitem><para>
  263. 古い形式の <acronym>API</acronym>: <classname>Zend_Validate_File_Size($min, $max, $bytestring)</classname>
  264. </para></listitem>
  265. <listitem><para>
  266. 新しい形式の <acronym>API</acronym>: <methodname>Zend_Validate_File_Size($options)</methodname>
  267. $options には次の配列キーを使えます。
  268. <emphasis>min</emphasis> ($min と同等)、
  269. <emphasis>max</emphasis> ($max と同等)、
  270. <emphasis>bytestring</emphasis> ($bytestring と同等)
  271. </para></listitem>
  272. </itemizedlist>
  273. <example id="zend.file.transfer.migration.fromonesixonetooneseven.validators.size.example">
  274. <title>size バリデータの 1.6 から 1.7 での変更点</title>
  275. <programlisting language="php"><![CDATA[
  276. // 1.6 の例
  277. $upload = new Zend_File_Transfer_Adapter_Http();
  278. $upload->addValidator('Size',
  279. array(100, 10000, true));
  280. // 1.7 の例
  281. $upload = new Zend_File_Transfer_Adapter_Http();
  282. $upload->addValidator('Size',
  283. false,
  284. array('min' => 100,
  285. 'max' => 10000,
  286. 'bytestring' => true));
  287. ]]></programlisting>
  288. </example>
  289. </sect4>
  290. </sect3>
  291. </sect2>
  292. <sect2 id="zend.file.transfer.migration.fromonesixonetoonesixtwo">
  293. <title>1.6.1 から 1.6.2 以降への移行</title>
  294. <sect3 id="zend.file.transfer.migration.fromonesixonetoonesixtwo.validators">
  295. <title>バリデータを使う際の変更点</title>
  296. <para>
  297. <classname>Zend_File_Transfer</classname> のバリデータが
  298. <classname>Zend_Form</classname> のデフォルトのものと同じようには動作しないという指摘がありました。
  299. <classname>Zend_Form</classname> では <classname>breakChainOnFailure</classname>
  300. パラメータを利用でき、検証エラーが発生した際に
  301. それ以降のバリデータを動作させないようにすることができます。
  302. </para>
  303. <para>
  304. そこで、<classname>Zend_File_Transfer</classname>
  305. の既存のバリデータにもこのパラメータを追加することにしました。
  306. </para>
  307. <itemizedlist>
  308. <listitem><para>
  309. 古い形式の <acronym>API</acronym>: <methodname>addValidator($validator, $options, $files)</methodname>.
  310. </para></listitem>
  311. <listitem><para>
  312. 新しい形式の <acronym>API</acronym>: <code>addValidator($validator, $breakChainOnFailure, $options, $files)</code>.
  313. </para></listitem>
  314. </itemizedlist>
  315. <para>
  316. 既存のスクリプトを新しい <acronym>API</acronym> に移行するには、バリデータの定義の後に
  317. <constant>FALSE</constant> を追加します。
  318. </para>
  319. <example id="zend.file.transfer.migration.fromonesixonetoonesixtwo.example">
  320. <title>ファイルバリデータを 1.6.1 から 1.6.2 に移行する方法</title>
  321. <programlisting language="php"><![CDATA[
  322. // 1.6.1 での例
  323. $upload = new Zend_File_Transfer_Adapter_Http();
  324. $upload->addValidator('FilesSize', array('1B', '100kB'));
  325. // 同じ例を 1.6.2 以降用にしたもの
  326. // boolean false が追加されていることに注意しましょう
  327. $upload = new Zend_File_Transfer_Adapter_Http();
  328. $upload->addValidator('FilesSize', false, array('1B', '100kB'));
  329. ]]></programlisting>
  330. </example>
  331. </sect3>
  332. </sect2>
  333. </sect1>