Zend_File_Transfer-Validators.xml 64 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 17685 -->
  4. <sect1 id="zend.file.transfer.validators">
  5. <title>Zend_File_Transfer 用のバリデータ</title>
  6. <para>
  7. <classname>Zend_File_Transfer</classname> にはファイル関連のバリデータがいくつか同梱されています。
  8. これらを使用してセキュリティを向上させ、攻撃から身を守るようにしましょう。
  9. バリデータは、それを使ってこそ役に立つものなのですから。
  10. <classname>Zend_File_Transfer</classname> が提供するバリデータは
  11. <classname>Zend_Validator</classname> コンポーネントに含まれ、
  12. <classname>Zend_Validate_File_*</classname> という名前がついています。
  13. 現在使用できるバリデータは次のとおりです。
  14. </para>
  15. <itemizedlist>
  16. <listitem>
  17. <para>
  18. <code>Count</code>: このバリデータはファイルの数をチェックします。
  19. 最小値と最大値を指定し、そのいずれかに違反した場合にエラーをスローします。
  20. </para>
  21. </listitem>
  22. <listitem>
  23. <para>
  24. <code>Crc32</code>: このバリデータはファイルの内容の crc32 ハッシュ値をチェックします。
  25. <code>Hash</code> バリデータをもとにしたもので、
  26. Crc32 のみをサポートする便利でシンプルなバリデータを提供します。
  27. </para>
  28. </listitem>
  29. <listitem>
  30. <para>
  31. <code>ExcludeExtension</code>: このバリデータはファイルの拡張子をチェックします。
  32. 渡されたファイルの拡張子が定義済みのものだった場合にエラーをスローします。
  33. これにより、特定の拡張子だけを除外できるようになります。
  34. </para>
  35. </listitem>
  36. <listitem>
  37. <para>
  38. <code>ExcludeMimeType</code>: このバリデータはファイルの <acronym>MIME</acronym> 型をチェックします。
  39. <acronym>MIME</acronym> 型の種類を検証し、指定したファイルの <acronym>MIME</acronym>
  40. 型がそれと一致するときにエラーをスローします。
  41. </para>
  42. </listitem>
  43. <listitem>
  44. <para>
  45. <code>Exists</code>: このバリデータはファイルの存在をチェックします。
  46. 指定したファイルが存在しない場合にエラーをスローします。
  47. </para>
  48. </listitem>
  49. <listitem>
  50. <para>
  51. <code>Extension</code>: このバリデータはファイルの拡張子をチェックします。
  52. 渡されたファイルの拡張子が未定義のものだった場合にエラーをスローします。
  53. </para>
  54. </listitem>
  55. <listitem>
  56. <para>
  57. <code>FilesSize</code>: このバリデータはすべてのファイルのサイズをチェックします。
  58. すべてのファイルのサイズを内部的に記憶し、
  59. その合計が制限値を超えた場合にエラーをスローします。
  60. サイズの最小値と最大値を指定することができます。
  61. </para>
  62. </listitem>
  63. <listitem>
  64. <para>
  65. <code>ImageSize</code>: このバリデータは画像のサイズをチェックします。
  66. 幅と高さについて、最小値と最大値を検証することができます。
  67. </para>
  68. </listitem>
  69. <listitem>
  70. <para>
  71. <code>IsCompressed</code>: このバリデータはファイルが圧縮されているかどうかをチェックします。
  72. <code>MimeType</code> バリデータにもとづいて、
  73. zip や arc といった圧縮アーカイブ形式かどうかを判断します。
  74. 特定のアーカイブ形式のみに制限することもできます。
  75. </para>
  76. </listitem>
  77. <listitem>
  78. <para>
  79. <code>IsImage</code>: このバリデータはファイルが画像であるかどうかをチェックします。
  80. <code>MimeType</code> バリデータにもとづいて、
  81. jpg や gif といった画像ファイルであるかどうかを判断します。
  82. 特定の画像形式のみに制限することもできます。
  83. </para>
  84. </listitem>
  85. <listitem>
  86. <para>
  87. <code>Hash</code>: このバリデータはファイルの内容のハッシュ値をチェックします。
  88. 複数のアルゴリズムをサポートしています。
  89. </para>
  90. </listitem>
  91. <listitem>
  92. <para>
  93. <code>Md5</code>: このバリデータはファイルの内容の md5 ハッシュ値をチェックします。
  94. <code>Hash</code> バリデータをもとにしたもので、
  95. Md5 のみをサポートする便利でシンプルなバリデータを提供します。
  96. </para>
  97. </listitem>
  98. <listitem>
  99. <para>
  100. <code>MimeType</code>: このバリデータはファイルの <acronym>MIME</acronym> 型をチェックします。
  101. <acronym>MIME</acronym> 型の種類を検証し、指定したファイルの <acronym>MIME</acronym>
  102. 型がそれと一致しないときにエラーをスローします。
  103. </para>
  104. </listitem>
  105. <listitem>
  106. <para>
  107. <code>NotExists</code>: このバリデータはファイルの存在をチェックします。
  108. 指定したファイルが存在する場合にエラーをスローします。
  109. </para>
  110. </listitem>
  111. <listitem>
  112. <para>
  113. <code>Sha1</code>: このバリデータはファイルの内容の sha1 ハッシュ値をチェックします。
  114. <code>Hash</code> バリデータをもとにしたもので、
  115. sha1 のみをサポートする便利でシンプルなバリデータを提供します。
  116. </para>
  117. </listitem>
  118. <listitem>
  119. <para>
  120. <code>Size</code>: このバリデータは各ファイルのサイズをチェックします。
  121. 最小値と最大値を指定し、そのいずれかに違反した場合にエラーをスローします。
  122. </para>
  123. </listitem>
  124. <listitem>
  125. <para>
  126. <code>Upload</code>: このバリデータは内部的に使用するもので、
  127. アップロード時に何らかの問題が発生していないかどうかをチェックします。
  128. 自分でこれを設定してはいけません。これは、
  129. <classname>Zend_File_Transfer</classname> 自身が自動的に設定します。
  130. ですので、このバリデータのことは忘れてしまってもかまいません。
  131. ただ、そういうバリデータが存在することだけを覚えておきましょう。
  132. </para>
  133. </listitem>
  134. <listitem>
  135. <para>
  136. <code>WordCount</code>: このバリデータはファイル内の単語数をチェックします。
  137. 最小値と最大値を指定し、そのいずれかに違反した場合にエラーをスローします。
  138. </para>
  139. </listitem>
  140. </itemizedlist>
  141. <sect2 id="zend.file.transfer.validators.usage">
  142. <title>Zend_File_Transfer でのバリデータの使用法</title>
  143. <para>
  144. バリデータの使い方はきわめて簡単です。
  145. バリデータを追加したり操作したりするには、次のメソッドを使用します。
  146. </para>
  147. <itemizedlist>
  148. <listitem>
  149. <para>
  150. <methodname>isValid($files = null)</methodname>:
  151. 指定したファイルがすべてのバリデータを使用したかどうかを調べます。
  152. <code>$files</code> には、実際のファイル名あるいは要素名、
  153. またはテンポラリファイル名を指定します。
  154. </para>
  155. </listitem>
  156. <listitem>
  157. <para>
  158. <code>addValidator($validator, $breakChainOnFailure, $options = null, $files =
  159. null)</code>: 指定したバリデータをバリデータスタックに追加します
  160. (オプションで、指定したファイルにだけ追加することもできます)。
  161. <code>$validator</code> に指定するのは、
  162. バリデータのインスタンスかあるいはバリデータの型の短い名前
  163. (たとえば 'Count') です。
  164. </para>
  165. </listitem>
  166. <listitem>
  167. <para>
  168. <code>addValidators(array $validators, $files =
  169. null)</code>: 指定した複数のバリデータをバリデータスタックに追加します。
  170. 各エントリは、バリデータの型とオプションのペアか
  171. あるいはキー 'validator' を持つ配列となります
  172. (配列の場合、バリデータのオプションはインスタンスの作成時に設定するものとします)。
  173. </para>
  174. </listitem>
  175. <listitem>
  176. <para>
  177. <code>setValidators(array $validators, $files =
  178. null)</code>: 既存のバリデータを、指定したバリデータで上書きします。
  179. バリデータの指定方法は <methodname>addValidators()</methodname>
  180. と同じです。
  181. </para>
  182. </listitem>
  183. <listitem>
  184. <para>
  185. <methodname>hasValidator($name)</methodname>:
  186. バリデータが登録されているかどうかを調べます。
  187. </para>
  188. </listitem>
  189. <listitem>
  190. <para>
  191. <methodname>getValidator($name)</methodname>:
  192. 前回登録されたバリデータを返します。
  193. </para>
  194. </listitem>
  195. <listitem>
  196. <para>
  197. <methodname>getValidators($files = null)</methodname>:
  198. 登録されているバリデータを返します。<code>$files</code>
  199. を渡すと、そのファイルに関連するバリデータを返します。
  200. </para>
  201. </listitem>
  202. <listitem>
  203. <para>
  204. <methodname>removeValidator($name)</methodname>:
  205. 前回登録されたバリデータを削除します。
  206. </para>
  207. </listitem>
  208. <listitem>
  209. <para>
  210. <methodname>clearValidators()</methodname>:
  211. 登録されているすべてのバリデータを消去します。
  212. </para>
  213. </listitem>
  214. </itemizedlist>
  215. <example id="zend.file.transfer.validators.usage.example">
  216. <title>ファイル転送用のバリデータの追加</title>
  217. <programlisting language="php"><![CDATA[
  218. $upload = new Zend_File_Transfer();
  219. // ファイルサイズを 20000 バイトに設定します
  220. $upload->addValidator('Size', false, 20000);
  221. // ファイルサイズの最小値を 20 バイト、最大値を 20000 バイトに設定します
  222. $upload->addValidator('Size', false, array('min' => 20, 'max' => 20000));
  223. // ファイルサイズの最小値を 20 バイト、最大値を 20000 バイトに設定し、
  224. // 同時にファイルの数も設定します
  225. $upload->setValidators(array(
  226. 'Size' => array('min' => 20, 'max' => 20000),
  227. 'Count' => array('min' => 1, 'max' => 3),
  228. ));
  229. ]]></programlisting>
  230. </example>
  231. <example id="zend.file.transfer.validators.usage.exampletwo">
  232. <title>特定のファイルに対してのみのバリデータの適用</title>
  233. <para>
  234. <methodname>addValidator()</methodname>、<methodname>addValidators()</methodname> および
  235. <methodname>setValidators()</methodname> は、それぞれ最後の引数
  236. <code>$files</code> を指定することができます。
  237. この引数にはファイル名あるいはファイル名の配列を指定し、
  238. 指定したファイルに対してのみバリデータを設定します。
  239. </para>
  240. <programlisting language="php"><![CDATA[
  241. $upload = new Zend_File_Transfer();
  242. // ファイルサイズを 20000 バイトとし、それを 'file2' にのみ適用します
  243. $upload->addValidator('Size', false, 20000, 'file2');
  244. ]]></programlisting>
  245. </example>
  246. <para>
  247. 一般的には、単純に <methodname>addValidators()</methodname>
  248. メソッドをコールすることになるでしょう。
  249. これは何度でもコールすることができます。
  250. </para>
  251. <example id="zend.file.transfer.validators.usage.examplemultiple">
  252. <title>複数のバリデータの追加</title>
  253. <para>
  254. 単に <methodname>addValidator()</methodname> を複数回コールするほうがシンプルに書けます。
  255. 個々のバリデータごとにコールするというわけです。
  256. これはコードの可読性も向上させ、保守性もあがります。
  257. すべてのメソッドは流れるようなインターフェイスを提供しているので、
  258. 複数回のコールは以下のように書くことができます。
  259. </para>
  260. <programlisting language="php"><![CDATA[
  261. $upload = new Zend_File_Transfer();
  262. // ファイルサイズを 20000 バイトに設定します
  263. $upload->addValidator('Size', false, 20000)
  264. ->addValidator('Count', false, 2)
  265. ->addValidator('Filessize', false, 25000);
  266. ]]></programlisting>
  267. </example>
  268. <note>
  269. <para>
  270. 同じバリデータを複数回設定することもできます。
  271. しかしそんなことをすると、
  272. 同じバリデータに異なるオプションを設定したときにおかしなことになるので注意しましょう。
  273. </para>
  274. </note>
  275. <para>
  276. 最後に、単純にファイルをチェックするには <methodname>isValid()</methodname> を使用します。
  277. </para>
  278. <example id="zend.file.transfer.validators.usage.exampleisvalid">
  279. <title>ファイルの検証</title>
  280. <para>
  281. <methodname>isValid()</methodname> には、
  282. アップロードあるいはダウンロードされるファイル名だけでなく、
  283. テンポラリファイル名やフォーム要素の名前を指定することもできます。
  284. パラメータを省略したり null を指定したりした場合は、
  285. すべてのファイルが検証対象となります。
  286. </para>
  287. <programlisting language="php"><![CDATA[
  288. $upload = new Zend_File_Transfer();
  289. // ファイルサイズを 20000 バイトに設定します
  290. $upload->addValidator('Size', false, 20000)
  291. ->addValidator('Count', false, 2)
  292. ->addValidator('Filessize', false, 25000);
  293. if ($upload->isValid()) {
  294. print "検証に失敗";
  295. }
  296. ]]></programlisting>
  297. </example>
  298. <note>
  299. <para>
  300. <methodname>isValid()</methodname> は、
  301. ファイルを受け取った際にそれまでコールされていなければ自動的にコールされることに注意しましょう。
  302. </para>
  303. </note>
  304. <para>
  305. 検証に失敗した場合は、何が問題だったのかについての情報を取得したくなることでしょう。
  306. <methodname>getMessages()</methodname> を使うとすべての検証メッセージを配列で取得できます。
  307. また <methodname>getErrors()</methodname> はすべてのエラーコードを返し、
  308. <methodname>hasErrors()</methodname> は検証エラーが見つかった時点で true を返します。
  309. </para>
  310. </sect2>
  311. <sect2 id="zend.file.transfer.validators.count">
  312. <title>Count バリデータ</title>
  313. <para>
  314. <code>Count</code> バリデータは、
  315. 渡されたファイルの数をチェックします。
  316. 次のオプションをサポートしています。
  317. </para>
  318. <itemizedlist>
  319. <listitem>
  320. <para>
  321. <code>min</code>: 転送するファイル数の最小値。
  322. </para>
  323. <note>
  324. <para>
  325. このオプションを使用する場合は、
  326. このバリデータを最初にコールした際にファイル数の最小値を指定する必要があります。
  327. そうしないとエラーが返されます。
  328. </para>
  329. </note>
  330. <para>
  331. このオプションで、受け取りたいファイル数の最小値を指定することができます。
  332. </para>
  333. </listitem>
  334. <listitem>
  335. <para>
  336. <code>max</code>: 転送するファイル数の最大値。
  337. </para>
  338. <para>
  339. このオプションで、受け取りたいファイル数を制限することができます。
  340. それだけでなく、フォームで定義されている以上の数のファイルを送られるなどの攻撃を防ぐこともできます。
  341. </para>
  342. </listitem>
  343. </itemizedlist>
  344. <para>
  345. 文字列あるいは整数値を指定してインスタンス化すると、その値は
  346. <code>max</code> とみなされます。あるいは、後から <methodname>setMin()</methodname> や
  347. <methodname>setMax()</methodname> でオプションを設定することもできますし、
  348. <methodname>getMin()</methodname> や <methodname>getMax()</methodname>
  349. で設定内容を取得することもできます。
  350. </para>
  351. <example id="zend.file.transfer.validators.count.example">
  352. <title>Count バリデータの使用法</title>
  353. <programlisting language="php"><![CDATA[
  354. $upload = new Zend_File_Transfer();
  355. // ファイルの数を最大 2 に制限します
  356. $upload->addValidator('Count', false, 2);
  357. // 最大でも 5 個、少なくとも 1 つのファイルが返されるよう制限します
  358. $upload->addValidator('Count', false, array('min' =>1, 'max' => 5));
  359. ]]></programlisting>
  360. </example>
  361. <note>
  362. <para>
  363. このバリデータは、チェックしたファイルの数を内部に保存することに注意しましょう。
  364. 最大値を超えたファイルはエラーを返します。
  365. </para>
  366. </note>
  367. </sect2>
  368. <sect2 id="zend.file.transfer.validators.crc32">
  369. <title>Crc32 バリデータ</title>
  370. <para>
  371. <code>Crc32</code> バリデータは、転送されたファイルの中身のハッシュをチェックします。
  372. このバリデータは、<acronym>PHP</acronym> の hash 拡張モジュールの crc32 アルゴリズムを使用します。
  373. 次のオプションをサポートしています。
  374. </para>
  375. <itemizedlist>
  376. <listitem>
  377. <para>
  378. <code>*</code>: 任意のキーあるいは数値添字配列を設定します。
  379. この値を、検証対象のハッシュと比較します。
  380. </para>
  381. <para>
  382. 異なるキーを使用して複数のハッシュを設定することができます。
  383. すべてのキーの内容をチェックし、
  384. どれにも一致しなかった場合にのみ検証が失敗します。
  385. </para>
  386. </listitem>
  387. </itemizedlist>
  388. <example id="zend.file.transfer.validators.crc32.example">
  389. <title>Crc32 バリデータの使用法</title>
  390. <programlisting language="php"><![CDATA[
  391. $upload = new Zend_File_Transfer();
  392. // アップロードされたファイルのハッシュが指定したものと一致するかどうかをチェックします
  393. $upload->addValidator('Crc32', false, '3b3652f');
  394. // ふたつの異なるハッシュを指定します
  395. $upload->addValidator('Crc32', false, array('3b3652f', 'e612b69'));
  396. ]]></programlisting>
  397. </example>
  398. </sect2>
  399. <sect2 id="zend.file.transfer.validators.excludeextension">
  400. <title>ExcludeExtension バリデータ</title>
  401. <para>
  402. <code>ExcludeExtension</code> バリデータは、
  403. 渡されたファイルの拡張子をチェックします。
  404. 次のオプションをサポートしています。
  405. </para>
  406. <itemizedlist>
  407. <listitem>
  408. <para>
  409. <code>*</code>: 任意のキーあるいは数値添字配列を指定します。
  410. 指定したファイルがこの拡張子を使用していないかどうかをチェックします。
  411. </para>
  412. </listitem>
  413. <listitem>
  414. <para>
  415. <code>case</code>: 検証時に大文字小文字を区別するかどうかを設定します。
  416. デフォルトでは大文字小文字を区別しません。
  417. このオプションはすべての拡張子に対して適用されることに注意しましょう。
  418. </para>
  419. </listitem>
  420. </itemizedlist>
  421. <para>
  422. このバリデータで複数の拡張子を指定するには、
  423. カンマ区切りの文字列あるいは配列を使用します。
  424. <methodname>setExtension()</methodname>、<methodname>addExtension()</methodname> および
  425. <methodname>getExtension()</methodname> といったメソッドで拡張子の設定や取得が可能です。
  426. </para>
  427. <para>
  428. 大文字小文字を区別したチェックが有用なこともあります。
  429. そのため、コンストラクタの 2 番目のパラメータ
  430. <code>$case</code> を指定できるようになっています。これを true
  431. に設定すると、大文字小文字を区別して拡張子を検証します。
  432. </para>
  433. <example id="zend.file.transfer.validators.excludeextension.example">
  434. <title>ExcludeExtension バリデータの使用法</title>
  435. <programlisting language="php"><![CDATA[
  436. $upload = new Zend_File_Transfer();
  437. // 拡張子 php あるいは exe のファイルは許可しません
  438. $upload->addValidator('ExcludeExtension', false, 'php,exe');
  439. // 拡張子 php あるいは exe のファイルを許可しない設定を配列記法で行います
  440. $upload->addValidator('ExcludeExtension', false, array('php', 'exe'));
  441. // 大文字小文字を区別するチェックを行います
  442. $upload->addValidator('ExcludeExtension',
  443. false,
  444. array('php', 'exe', 'case' => true));
  445. $upload->addValidator('ExcludeExtension',
  446. false,
  447. array('php', 'exe', 'case' => true));
  448. ]]></programlisting>
  449. </example>
  450. <note>
  451. <para>
  452. このバリデータがチェックするのはファイルの拡張子のみであることに注意しましょう。
  453. 実際の <acronym>MIME</acronym> 型などはチェックしません。
  454. </para>
  455. </note>
  456. </sect2>
  457. <sect2 id="zend.file.transfer.validators.excludemimetype">
  458. <title>ExcludeMimeType バリデータ</title>
  459. <para>
  460. <code>ExcludeMimeType</code> バリデータは、
  461. 転送されるファイルの <acronym>MIME</acronym> 型をチェックします。
  462. 次のオプションをサポートしています。
  463. </para>
  464. <itemizedlist>
  465. <listitem>
  466. <para>
  467. <code>*</code>: 任意のキー、あるいは数値添字配列を指定します。
  468. 検証したい <acronym>MIME</acronym> 型を設定します。
  469. </para>
  470. <para>
  471. このオプションで、許可したくないファイルの <acronym>MIME</acronym> 型を定義することができます。
  472. </para>
  473. </listitem>
  474. <listitem>
  475. <para>
  476. <code>headerCheck</code>: <constant>TRUE</constant> に設定すると、
  477. <emphasis>fileInfo</emphasis> あるいは <emphasis>mimeMagic</emphasis>
  478. 拡張モジュールがない場合にも <acronym>HTTP</acronym>
  479. 情報からファイルタイプをチェックします。このオプションのデフォルト値は
  480. <constant>FALSE</constant> です。
  481. </para>
  482. </listitem>
  483. </itemizedlist>
  484. <para>
  485. このバリデータで複数の <acronym>MIME</acronym> 型を指定するには、
  486. カンマ区切りの文字列あるいは配列を使用します。
  487. <methodname>setMimeType()</methodname>、<methodname>addMimeType()</methodname> および
  488. <methodname>getMimeType()</methodname> といったメソッドで <acronym>MIME</acronym> 型の設定や取得が可能です。
  489. </para>
  490. <example id="zend.file.transfer.validators.excludemimetype.example">
  491. <title>ExcludeMimeType バリデータの使用法</title>
  492. <programlisting language="php"><![CDATA[
  493. $upload = new Zend_File_Transfer();
  494. // すべてのファイルで gif 画像の MIME 型を許可しません
  495. $upload->addValidator('ExcludeMimeType', false, 'image/gif');
  496. // すべてのファイルで gif 画像および jpg 画像の MIME 型を許可しません
  497. $upload->addValidator('ExcludeMimeType', false, array('image/gif', 'image/jpeg');
  498. // すべてのファイルで画像を許可しません
  499. $upload->addValidator('ExcludeMimeType', false, 'image');
  500. ]]></programlisting>
  501. </example>
  502. <para>
  503. 上の例で示したように、複数の <acronym>MIME</acronym> 型をひとつのグループとして扱うこともできます。
  504. 画像ファイルならすべて許可したいという場合は、<acronym>MIME</acronym> 型に 'image' と指定します。
  505. 'image' 以外にも 'audio'、'video'、'text などが使用可能です。
  506. </para>
  507. <note>
  508. <para>
  509. <acronym>MIME</acronym> 型のグループを拒否してしまうと、意図していないものも含めて
  510. そのグループのすべての形式のファイルを拒否してしまうことに注意しましょう。
  511. たとえば 'image' を拒否したら 'image/jpeg' や 'image/vasa'
  512. などすべての画像形式を拒否することになります。
  513. すべての形式を拒否していいのかどうか不安な場合は、
  514. グループ指定ではなく個別の <acronym>MIME</acronym> 型を指定するようにしましょう。
  515. </para>
  516. </note>
  517. </sect2>
  518. <sect2 id="zend.file.transfer.validators.exists">
  519. <title>Exists バリデータ</title>
  520. <para>
  521. <code>Exists</code> バリデータは、
  522. 指定したファイルの存在をチェックします。
  523. 次のオプションをサポートしています。
  524. </para>
  525. <itemizedlist>
  526. <listitem>
  527. <para>
  528. <code>*</code>: 任意のキーあるいは数値添字配列を指定し、
  529. ファイルが指定したディレクトリに存在するかどうかをチェックします。
  530. </para>
  531. </listitem>
  532. </itemizedlist>
  533. <para>
  534. このバリデータで複数のディレクトリを指定するには、
  535. カンマ区切りの文字列あるいは配列を使用します。
  536. <methodname>setDirectory()</methodname>、<methodname>addDirectory()</methodname> および
  537. <methodname>getDirectory()</methodname> といったメソッドでディレクトリの設定や取得が可能です。
  538. </para>
  539. <example id="zend.file.transfer.validators.exists.example">
  540. <title>Exists バリデータの使用法</title>
  541. <programlisting language="php"><![CDATA[
  542. $upload = new Zend_File_Transfer();
  543. // temp ディレクトリをチェック対象に追加します
  544. $upload->addValidator('Exists', false, '\temp');
  545. // ふたつのディレクトリを配列記法で追加します
  546. $upload->addValidator('Exists',
  547. false,
  548. array('\home\images', '\home\uploads'));
  549. ]]></programlisting>
  550. </example>
  551. <note>
  552. <para>
  553. このバリデータは、ファイルが存在するかどうかをすべてのディレクトリでチェックすることに注意しましょう。
  554. 指定したディレクトリのうちのどこかひとつでもファイルが存在しなかった場合に検証が失敗します。
  555. </para>
  556. </note>
  557. </sect2>
  558. <sect2 id="zend.file.transfer.validators.extension">
  559. <title>Extension バリデータ</title>
  560. <para>
  561. <code>Extension</code> バリデータは、
  562. 渡されたファイルの拡張子をチェックします。
  563. 次のオプションをサポートしています。
  564. </para>
  565. <itemizedlist>
  566. <listitem>
  567. <para>
  568. <code>*</code>: 任意のキーあるいは数値添字配列を設定し、
  569. 指定したファイルがこの拡張子かどうかをチェックします。
  570. </para>
  571. </listitem>
  572. <listitem>
  573. <para>
  574. <code>case</code>: チェックの際に大文字小文字を区別するかどうかを設定します。
  575. デフォルトでは大文字小文字を区別しません。
  576. このオプションは、すべての拡張子に対して適用されることに注意しましょう。
  577. </para>
  578. </listitem>
  579. </itemizedlist>
  580. <para>
  581. このバリデータで複数の拡張子を指定するには、
  582. カンマ区切りの文字列あるいは配列を使用します。
  583. <methodname>setExtension()</methodname>、<methodname>addExtension()</methodname> および
  584. <methodname>getExtension()</methodname> といったメソッドで拡張子の設定や取得が可能です。
  585. </para>
  586. <para>
  587. 場合によっては大文字小文字を区別してチェックしたくなることもあるでしょう。
  588. そんなときのために、コンストラクタで 2 番目のパラメータ
  589. <code>$case</code> を指定することができます。これを true
  590. にすると、大文字小文字を区別して拡張子のチェックを行います。
  591. </para>
  592. <example id="zend.file.transfer.validators.extension.example">
  593. <title>Extension バリデータの使用法</title>
  594. <programlisting language="php"><![CDATA[
  595. $upload = new Zend_File_Transfer();
  596. // 拡張子を jpg と png のみに制限します
  597. $upload->addValidator('Extension', false, 'jpg,png');
  598. // 配列形式で、拡張子を jpg と png のみに制限します
  599. $upload->addValidator('Extension', false, array('jpg', 'png'));
  600. // 大文字小文字を区別したチェックを行います
  601. $upload->addValidator('Extension', false, array('mo', 'png', 'case' => true));
  602. if (!$upload->isValid('C:\temp\myfile.MO')) {
  603. print 'Not valid because MO and mo do not match with case sensitivity;
  604. }
  605. ]]></programlisting>
  606. </example>
  607. <note>
  608. <para>
  609. このバリデータがチェックするのはファイルの拡張子のみであることに注意しましょう。
  610. 実際の <acronym>MIME</acronym> 型などはチェックしません。
  611. </para>
  612. </note>
  613. </sect2>
  614. <sect2 id="zend.file.transfer.validators.filessize">
  615. <title>FilesSize バリデータ</title>
  616. <para>
  617. <code>FilesSize</code> バリデータは、
  618. すべてのファイルの合計サイズをチェックします。
  619. 次のオプションをサポートしています。
  620. </para>
  621. <itemizedlist>
  622. <listitem>
  623. <para>
  624. <code>min</code>: ファイルサイズの総合計の最小値を設定します。
  625. このオプションで、転送されるファイルの合計サイズの最小値を指定します。
  626. </para>
  627. </listitem>
  628. <listitem>
  629. <para>
  630. <code>max</code>: ファイルサイズの総合計の最大値を設定します。
  631. </para>
  632. <para>
  633. このオプションで、転送されるファイルの合計サイズの最大値を指定することができます。
  634. 個別のファイルのサイズはチェックしません。
  635. </para>
  636. </listitem>
  637. <listitem>
  638. <para>
  639. <code>bytestring</code>: 失敗したときに返す情報を、
  640. 人間が読みやすい形式にするかファイルサイズそのものにするかを設定します。
  641. </para>
  642. <para>
  643. このオプションで、ユーザが受け取る結果が '10864' あるいは '10MB'
  644. のどちらの形式になるのかを指定することができます。デフォルト値は
  645. true で、'10MB' 形式となります。
  646. </para>
  647. </listitem>
  648. </itemizedlist>
  649. <para>
  650. 文字列を指定してインスタンス化すると、その値は
  651. <code>max</code> とみなされます。
  652. 後から <methodname>setMin()</methodname> や
  653. <methodname>setMax()</methodname> でオプションを設定することもできますし、
  654. <methodname>getMin()</methodname> や <methodname>getMax()</methodname>
  655. で設定内容を取得することもできます。
  656. </para>
  657. <para>
  658. サイズの指定には SI 記法も使えます。
  659. これは多くのオペレーティングシステムでもサポートされているものです。
  660. <emphasis>20000 bytes</emphasis>
  661. と書くかわりに、<emphasis>20kB</emphasis>
  662. とすることができるのです。すべての単位は、1024 単位に変換されます。
  663. 使用できる単位は <code>kB</code>、<code>MB</code>、
  664. <code>GB</code>、<code>TB</code>、<code>PB</code> および <code>EB</code>
  665. です。先ほど説明したとおり、1kB は 1024 バイトであることに注意する必要があります。
  666. </para>
  667. <example id="zend.file.transfer.validators.filessize.example">
  668. <title>FilesSize バリデータの使用法</title>
  669. <programlisting language="php"><![CDATA[
  670. $upload = new Zend_File_Transfer();
  671. // アップロードされるファイルサイズの合計を 40000 バイトまでに制限します
  672. $upload->addValidator('FilesSize', false, 40000);
  673. // アップロードされるファイルサイズの合計を最大 4MB、最小 10kB に制限します
  674. $upload->addValidator('FilesSize',
  675. false,
  676. array('min' => '10kB', 'max' => '4MB'));
  677. // さきほどと同じですが、結果をプレーンなファイルサイズで返します
  678. $upload->addValidator('FilesSize',
  679. false,
  680. array('min' => '10kB',
  681. 'max' => '4MB',
  682. 'bytestring' => false));
  683. ]]></programlisting>
  684. </example>
  685. <note>
  686. <para>
  687. このバリデータは、チェックしたファイルのサイズを内部に保存することに注意しましょう。
  688. 最大値を超えたファイルはエラーを返します。
  689. </para>
  690. </note>
  691. </sect2>
  692. <sect2 id="zend.file.transfer.validators.imagesize">
  693. <title>ImageSize バリデータ</title>
  694. <para>
  695. <code>ImageSize</code> バリデータは、
  696. 画像ファイルのサイズをチェックします。
  697. 次のオプションをサポートしています。
  698. </para>
  699. <itemizedlist>
  700. <listitem>
  701. <para>
  702. <code>minheight</code>: 画像の高さの最小値を設定します。
  703. </para>
  704. </listitem>
  705. <listitem>
  706. <para>
  707. <code>maxheight</code>: 画像の高さの最大値を設定します。
  708. </para>
  709. </listitem>
  710. <listitem>
  711. <para>
  712. <code>minwidth</code>: 画像の幅の最小値を設定します。
  713. </para>
  714. </listitem>
  715. <listitem>
  716. <para>
  717. <code>maxwidth</code>: 画像の幅の最大値を設定します。
  718. </para>
  719. </listitem>
  720. </itemizedlist>
  721. <para>
  722. <methodname>setImageMin()</methodname> や <methodname>setImageMax()</methodname>
  723. で最小値・最大値を設定することもできますし、
  724. <methodname>getMin()</methodname> や <methodname>getMax()</methodname>
  725. で設定内容を取得することもできます。
  726. </para>
  727. <para>
  728. 利便性を考慮して、<methodname>setImageWidth()</methodname> や <methodname>setImageHeight()</methodname>
  729. といったメソッドも用意されています。これは、幅や高さの最小値と最大値を設定します。
  730. もちろん、それに対応する <methodname>getImageWidth()</methodname> や <methodname>getImageHeight()</methodname>
  731. も使用可能です。
  732. </para>
  733. <para>
  734. サイズの検証をしたくない場合は、その部分に値 <constant>NULL</constant> を設定します。
  735. </para>
  736. <example id="zend.file.transfer.validators.imagesize.example">
  737. <title>ImageSize バリデータの使用法</title>
  738. <programlisting language="php"><![CDATA[
  739. $upload = new Zend_File_Transfer();
  740. // 画像の高さを 100-200 ピクセル、幅を 40-80 ピクセルに制限します
  741. $upload->addValidator('ImageSize', false,
  742. array('minwidth' => 40,
  743. 'maxwidth' => 80,
  744. 'minheight' => 100,
  745. 'maxheight' => 200)
  746. );
  747. // 検証用の幅をリセットします
  748. $upload->setImageWidth(array('minwidth' => 20, 'maxwidth' => 200));
  749. ]]></programlisting>
  750. </example>
  751. </sect2>
  752. <sect2 id="zend.file.transfer.validators.iscompressed">
  753. <title>IsCompressed バリデータ</title>
  754. <para>
  755. <code>IsCompressed</code> バリデータは、
  756. 転送されたファイルが zip や arc のような圧縮アーカイブ形式であるかどうかをチェックします。
  757. このバリデータは <code>MimeType</code> バリデータを使用しており、
  758. 同じメソッドとオプションをサポートしています。
  759. このバリデータを特定の圧縮形式のみに制限するには、
  760. そのメソッドを使用します。
  761. </para>
  762. <example id="zend.file.transfer.validators.iscompressed.example">
  763. <title>IsCompressed バリデータの使用法</title>
  764. <programlisting language="php"><![CDATA[
  765. $upload = new Zend_File_Transfer();
  766. // アップロードされたファイルが圧縮アーカイブであるかどうかチェックします
  767. $upload->addValidator('IsCompressed', false);
  768. // zip ファイルのみを対象とするようこのバリデータを制限します
  769. $upload->addValidator('IsCompressed', false, array('application/zip'));
  770. // よりシンプルな記法で、zip ファイルのみを対象とするようこのバリデータを制限します
  771. $upload->addValidator('IsCompressed', false, 'zip');
  772. ]]></programlisting>
  773. </example>
  774. <note>
  775. <para>
  776. 指定した <acronym>MIME</acronym>
  777. 型がアーカイブ型であるかどうかのチェックは行われないことに注意しましょう。
  778. たとえば gif ファイルがこのバリデータを通過するように設定することも可能です。
  779. アーカイブ型かどうかのチェックには 'MimeType'
  780. バリデータを使用したほうが読みやすいコードとなります。
  781. </para>
  782. </note>
  783. </sect2>
  784. <sect2 id="zend.file.transfer.validators.isimage">
  785. <title>IsImage バリデータ</title>
  786. <para>
  787. <code>IsImage</code> バリデータは、
  788. 転送されたファイルが gif や jpeg のような画像ファイルであるかどうかをチェックします。
  789. このバリデータは <code>MimeType</code> バリデータを使用しており、
  790. 同じメソッドとオプションをサポートしています。
  791. このバリデータを特定の画像形式のみに制限するには、
  792. そのメソッドを使用します。
  793. </para>
  794. <example id="zend.file.transfer.validators.isimage.example">
  795. <title>IsImage バリデータの使用法</title>
  796. <programlisting language="php"><![CDATA[
  797. $upload = new Zend_File_Transfer();
  798. // アップロードされたファイルが画像ファイルであるかどうかチェックします
  799. $upload->addValidator('IsImage', false);
  800. // gif ファイルのみを対象とするようこのバリデータを制限します
  801. $upload->addValidator('IsImage', false, array('application/gif'));
  802. // よりシンプルな記法で、gif ファイルのみを対象とするようこのバリデータを制限します
  803. $upload->addValidator('IsImage', false, 'jpeg');
  804. ]]></programlisting>
  805. </example>
  806. <note>
  807. <para>
  808. 指定した <acronym>MIME</acronym>
  809. 型が image 型であるかどうかのチェックは行われないことに注意しましょう。
  810. たとえば gif ファイルがこのバリデータを通過するように設定することも可能です。
  811. image 型かどうかのチェックには 'MimeType'
  812. バリデータを使用したほうが読みやすいコードとなります。
  813. </para>
  814. </note>
  815. </sect2>
  816. <sect2 id="zend.file.transfer.validators.hash">
  817. <title>Hash バリデータ</title>
  818. <para>
  819. <code>Hash</code> バリデータは、転送されたファイルの中身のハッシュをチェックします。
  820. このバリデータは、<acronym>PHP</acronym> の hash 拡張モジュールを使用します。
  821. 次のオプションをサポートしています。
  822. </para>
  823. <itemizedlist>
  824. <listitem>
  825. <para>
  826. <code>*</code>: 任意のキーあるいは数値添字配列を設定します。
  827. この値と、検証対象のハッシュとを比較します。
  828. </para>
  829. <para>
  830. 配列形式で複数のハッシュを設定することができます。
  831. すべてのキーの内容をチェックし、
  832. どれにも一致しなかった場合にのみ検証が失敗します。
  833. </para>
  834. </listitem>
  835. <listitem>
  836. <para>
  837. <code>algorithm</code>: ハッシュの取得に使用するアルゴリズムを設定します。
  838. </para>
  839. <para>
  840. 複数のアルゴリズムを設定するには、<methodname>addHash()</methodname>
  841. メソッドを複数回コールします。
  842. </para>
  843. </listitem>
  844. </itemizedlist>
  845. <example id="zend.file.transfer.validators.hash.example">
  846. <title>Hash バリデータの使用法</title>
  847. <programlisting language="php"><![CDATA[
  848. $upload = new Zend_File_Transfer();
  849. // アップロードされたファイルのハッシュが指定したものと一致するかどうかをチェックします
  850. $upload->addValidator('Hash', false, '3b3652f');
  851. // ふたつの異なるハッシュを指定します
  852. $upload->addValidator('Hash', false, array('3b3652f', 'e612b69'));
  853. // 別のアルゴリズムでチェックを行います
  854. $upload->addValidator('Hash',
  855. false,
  856. array('315b3cd8273d44912a7',
  857. 'algorithm' => 'md5'));
  858. ]]></programlisting>
  859. </example>
  860. <note>
  861. <para>
  862. このバリデータは、役 34 のハッシュアルゴリズムをサポートしています。
  863. よく使われるものとしては 'crc32' や 'md5' そして 'sha1' があります。
  864. サポートするアルゴリズムの一覧は、
  865. <ulink url="http://php.net">php.net</ulink> の
  866. <ulink url="http://php.net/hash_algos">hash_algos メソッド</ulink>
  867. を参照ください。
  868. </para>
  869. </note>
  870. </sect2>
  871. <sect2 id="zend.file.transfer.validators.md5">
  872. <title>Md5 バリデータ</title>
  873. <para>
  874. <code>Md5</code> バリデータは、転送されたファイルの中身のハッシュをチェックします。
  875. このバリデータは、<acronym>PHP</acronym> の hash 拡張モジュールの md5 アルゴリズムを使用します。
  876. 次のオプションをサポートしています。
  877. </para>
  878. <itemizedlist>
  879. <listitem>
  880. <para>
  881. <code>*</code>: 任意のキーあるいは数値添字配列を設定します。
  882. </para>
  883. <para>
  884. 配列形式で複数のハッシュを設定することができます。
  885. すべてのキーの内容をチェックし、
  886. どれにも一致しなかった場合にのみ検証が失敗します。
  887. </para>
  888. </listitem>
  889. </itemizedlist>
  890. <example id="zend.file.transfer.validators.md5.example">
  891. <title>Md5 バリデータの使用法</title>
  892. <programlisting language="php"><![CDATA[
  893. $upload = new Zend_File_Transfer();
  894. // アップロードされたファイルのハッシュが指定したものと一致するかどうかをチェックします
  895. $upload->addValidator('Md5', false, '3b3652f336522365223');
  896. // ふたつの異なるハッシュを指定します
  897. $upload->addValidator('Md5',
  898. false,
  899. array('3b3652f336522365223',
  900. 'eb3365f3365ddc65365'));
  901. ]]></programlisting>
  902. </example>
  903. </sect2>
  904. <sect2 id="zend.file.transfer.validators.mimetype">
  905. <title>MimeType バリデータ</title>
  906. <para>
  907. <code>MimeType</code> バリデータは、
  908. 転送されるファイルの <acronym>MIME</acronym> 型をチェックします。
  909. 次のオプションをサポートしています。
  910. </para>
  911. <itemizedlist>
  912. <listitem>
  913. <para>
  914. <code>*</code>: 任意のキーあるいは数値添字配列を指定します。
  915. 検証したい <acronym>MIME</acronym> 型を設定します。
  916. </para>
  917. <para>
  918. 許可したいファイルの <acronym>MIME</acronym> 型を定義します。
  919. </para>
  920. </listitem>
  921. <listitem>
  922. <para>
  923. <code>headerCheck</code>: <constant>TRUE</constant> に設定すると、
  924. <emphasis>fileInfo</emphasis> あるいは <emphasis>mimeMagic</emphasis>
  925. 拡張モジュールがない場合にも <acronym>HTTP</acronym>
  926. 情報からファイルタイプをチェックします。このオプションのデフォルト値は
  927. <constant>FALSE</constant> です。
  928. </para>
  929. </listitem>
  930. <listitem>
  931. <para>
  932. <code>magicfile</code>: 使用する magicfile。
  933. </para>
  934. <para>
  935. このオプションで、使用する magicfile を定義します。
  936. 指定しなかったり空だったりした場合は、定数 MAGIC
  937. を使用します。このオプションは Zend Framework 1.7.1
  938. 以降で使用可能です。
  939. </para>
  940. </listitem>
  941. </itemizedlist>
  942. <para>
  943. このバリデータで複数の <acronym>MIME</acronym> 型を指定するには、
  944. カンマ区切りの文字列あるいは配列を使用します。
  945. <methodname>setMimeType()</methodname>、<methodname>addMimeType()</methodname> および
  946. <methodname>getMimeType()</methodname> といったメソッドで <acronym>MIME</acronym> 型の設定や取得が可能です。
  947. </para>
  948. <para>
  949. fileinfo が使用する magicfile を設定するには、オプション 'magicfile' を使用します。
  950. さらに、<methodname>setMagicFile()</methodname> や <methodname>getMagicFile()</methodname>
  951. といったメソッドで後から magicfile の設定や取得が可能です。
  952. これらのメソッドは Zend Framework 1.7.1 以降で使用可能です。
  953. </para>
  954. <example id="zend.file.transfer.validators.mimetype.example">
  955. <title>MimeType バリデータの使用法</title>
  956. <programlisting language="php"><![CDATA[
  957. $upload = new Zend_File_Transfer();
  958. // MIME 型を制限し、gif 画像のみを許可するようにします
  959. $upload->addValidator('MimeType', false, 'image/gif');
  960. // すべてのファイルが gif および jpeg 画像でなければならないように MIME 型を制限します
  961. $upload->addValidator('MimeType', false, array('image/gif', 'image/jpeg');
  962. // すべてのファイルが画像であるように MIME 型を制限します
  963. $upload->addValidator('MimeType', false, 'image');
  964. // 別の magicfile を使用します
  965. $upload->addValidator('MimeType',
  966. false,
  967. array('image',
  968. 'magicfile' => '/path/to/magicfile.mgx'));
  969. ]]></programlisting>
  970. </example>
  971. <para>
  972. 上の例で示したように、複数の <acronym>MIME</acronym> 型をひとつのグループとして扱うこともできます。
  973. 画像ファイルならすべて許可したいという場合は、<acronym>MIME</acronym> 型に 'image' と指定します。
  974. 'image' 以外にも 'audio'、'video'、'text などが使用可能です。
  975. </para>
  976. <note>
  977. <para>
  978. <acronym>MIME</acronym> 型のグループを許可してしまうと、アプリケーション側で対応しているか否かにかかわらず
  979. そのグループのすべての形式のファイルを許可してしまうことに注意しましょう。
  980. たとえば 'image' を許可したら 'image/xpixmap' や 'image/vasa'
  981. も受け付けることになりますが、おそらくこれは問題となるでしょう。
  982. アプリケーション側ですべての形式を処理できるかどうか不安なら、
  983. グループ指定ではなく個別の <acronym>MIME</acronym> 型を指定するようにしましょう。
  984. </para>
  985. </note>
  986. <note>
  987. <para>
  988. このコンポーネントは、もし <code>fileinfo</code>
  989. 拡張モジュールが使用可能ならそれを使用します。使用できない場合は
  990. <code>mime_content_type</code> 関数を使用します。
  991. この関数コールが失敗した場合は、<acronym>HTTP</acronym> で渡された <acronym>MIME</acronym> 型を使用します。
  992. </para>
  993. <para>
  994. <code>fileinfo</code> も <code>mime_content_type</code>
  995. も使えない場合は、セキュリティの問題に注意する必要があります。
  996. <acronym>HTTP</acronym> から取得する <acronym>MIME</acronym> 型はセキュアではなく、
  997. 容易に改ざんすることができます。
  998. </para>
  999. </note>
  1000. </sect2>
  1001. <sect2 id="zend.file.transfer.validators.notexists">
  1002. <title>NotExists バリデータ</title>
  1003. <para>
  1004. <code>NotExists</code> バリデータは、
  1005. 指定したファイルの存在をチェックします。
  1006. 次のオプションをサポートしています。
  1007. </para>
  1008. <itemizedlist>
  1009. <listitem>
  1010. <para>
  1011. <code>*</code>: 任意のキーあるいは数値添字配列を設定し、
  1012. ファイルが指定したディレクトリに存在しないかどうかをチェックします。
  1013. </para>
  1014. </listitem>
  1015. </itemizedlist>
  1016. <para>
  1017. このバリデータで複数のディレクトリを指定するには、
  1018. カンマ区切りの文字列あるいは配列を使用します。
  1019. <methodname>setDirectory()</methodname>、<methodname>addDirectory()</methodname> および
  1020. <methodname>getDirectory()</methodname> といったメソッドでディレクトリの設定や取得が可能です。
  1021. </para>
  1022. <example id="zend.file.transfer.validators.notexists.example">
  1023. <title>NotExists バリデータの使用法</title>
  1024. <programlisting language="php"><![CDATA[
  1025. $upload = new Zend_File_Transfer();
  1026. // temp ディレクトリをチェック対象に追加します
  1027. $upload->addValidator('NotExists', false, '\temp');
  1028. // ふたつのディレクトリを配列記法で追加します
  1029. $upload->addValidator('NotExists', false,
  1030. array('\home\images',
  1031. '\home\uploads')
  1032. );
  1033. ]]></programlisting>
  1034. </example>
  1035. <note>
  1036. <para>
  1037. このバリデータは、ファイルが存在しないかどうかをすべてのディレクトリでチェックすることに注意しましょう。
  1038. 指定したディレクトリのうちのどこかひとつでもファイルが存在した場合に検証が失敗します。
  1039. </para>
  1040. </note>
  1041. </sect2>
  1042. <sect2 id="zend.file.transfer.validators.sha1">
  1043. <title>Sha1 バリデータ</title>
  1044. <para>
  1045. <code>Sha1</code> バリデータは、転送されたファイルの中身のハッシュをチェックします。
  1046. このバリデータは、<acronym>PHP</acronym> の hash 拡張モジュールの sha1 アルゴリズムを使用します。
  1047. 次のオプションをサポートしています。
  1048. </para>
  1049. <itemizedlist>
  1050. <listitem>
  1051. <para>
  1052. <code>*</code>: 任意のキーあるいは数値添字配列を設定します。
  1053. </para>
  1054. <para>
  1055. 配列形式で複数のハッシュを設定することができます。
  1056. すべてのキーの内容をチェックし、
  1057. どれにも一致しなかった場合にのみ検証が失敗します。
  1058. </para>
  1059. </listitem>
  1060. </itemizedlist>
  1061. <example id="zend.file.transfer.validators.sha1.example">
  1062. <title>sha1 バリデータの使用法</title>
  1063. <programlisting language="php"><![CDATA[
  1064. $upload = new Zend_File_Transfer();
  1065. // アップロードされたファイルのハッシュが指定したものと一致するかどうかをチェックします
  1066. $upload->addValidator('sha1', false, '3b3652f336522365223');
  1067. // ふたつの異なるハッシュを指定します
  1068. $upload->addValidator('Sha1',
  1069. false, array('3b3652f336522365223',
  1070. 'eb3365f3365ddc65365'));
  1071. ]]></programlisting>
  1072. </example>
  1073. </sect2>
  1074. <sect2 id="zend.file.transfer.validators.size">
  1075. <title>Size バリデータ</title>
  1076. <para>
  1077. <code>Size</code> バリデータは、
  1078. 個々のファイルのサイズをチェックします。
  1079. 次のオプションをサポートしています。
  1080. </para>
  1081. <itemizedlist>
  1082. <listitem>
  1083. <para>
  1084. <code>Min</code>: ファイルサイズの最小値を設定します。
  1085. </para>
  1086. <para>
  1087. このオプションで、転送されるファイルの個々のサイズの最小値を指定することができます。
  1088. </para>
  1089. </listitem>
  1090. <listitem>
  1091. <para>
  1092. <code>Max</code>: ファイルサイズの最大値を設定します。
  1093. </para>
  1094. <para>
  1095. このオプションで、転送されるファイルの個々のサイズを制限することができます。
  1096. </para>
  1097. </listitem>
  1098. <listitem>
  1099. <para>
  1100. <code>bytestring</code>: 失敗したときに返す情報を、
  1101. 人間が読みやすい形式にするかファイルサイズそのものにするかを設定します。
  1102. </para>
  1103. <para>
  1104. このオプションで、ユーザが受け取る結果が '10864' あるいは '10MB'
  1105. のどちらの形式になるのかを指定することができます。デフォルト値は
  1106. true で、'10MB' 形式となります。
  1107. </para>
  1108. </listitem>
  1109. </itemizedlist>
  1110. <para>
  1111. 文字列を指定してインスタンス化すると、その値は
  1112. <code>max</code> とみなされます。あるいは、後から <methodname>setMin()</methodname> や
  1113. <methodname>setMax()</methodname> でオプションを設定することもできますし、
  1114. <methodname>getMin()</methodname> や <methodname>getMax()</methodname>
  1115. で設定内容を取得することもできます。
  1116. </para>
  1117. <para>
  1118. サイズの指定には SI 記法も使えます。
  1119. これは多くのオペレーティングシステムでもサポートされているものです。
  1120. <emphasis>20000 bytes</emphasis>
  1121. と書くかわりに、<emphasis>20kB</emphasis>
  1122. とすることができるのです。すべての単位は、1024 単位に変換されます。
  1123. 使用できる単位は <code>kB</code>、<code>MB</code>、
  1124. <code>GB</code>、<code>TB</code>、<code>PB</code> および <code>EB</code>
  1125. です。先ほど説明したとおり、1kB は 1024 バイトであることに注意する必要があります。
  1126. </para>
  1127. <example id="zend.file.transfer.validators.size.example">
  1128. <title>Size バリデータの使用法</title>
  1129. <programlisting language="php"><![CDATA[
  1130. $upload = new Zend_File_Transfer();
  1131. // ファイルサイズを 40000 バイトまでに制限します
  1132. $upload->addValidator('Size', false, 40000);
  1133. // 指定したファイルのサイズを最大 4MB、最小 10kB に制限し、
  1134. // さらにエラー時に返す結果をユーザに優しい形式ではなく
  1135. // プレーンな数値とします
  1136. $upload->addValidator('Size',
  1137. false,
  1138. array('min' => '10kB',
  1139. 'max' => '4MB',
  1140. 'bytestring' => false));
  1141. ]]></programlisting>
  1142. </example>
  1143. </sect2>
  1144. <sect2 id="zend.file.transfer.validators.wordcount">
  1145. <title>WordCount バリデータ</title>
  1146. <para>
  1147. <code>WordCount</code> バリデータは、
  1148. 指定したファイル内の単語数をチェックします。
  1149. 次のオプションをサポートしています。
  1150. </para>
  1151. <itemizedlist>
  1152. <listitem>
  1153. <para>
  1154. <code>min</code>: 見つかった単語数の最小値を設定します。
  1155. </para>
  1156. </listitem>
  1157. <listitem>
  1158. <para>
  1159. <code>max</code>: 見つかった単語数の最大値を設定します。
  1160. </para>
  1161. </listitem>
  1162. </itemizedlist>
  1163. <para>
  1164. 文字列あるいは整数値を指定してインスタンス化すると、その値は
  1165. <code>max</code> とみなされます。あるいは、後から <methodname>setMin()</methodname> や
  1166. <methodname>setMax()</methodname> でオプションを設定することもできますし、
  1167. <methodname>getMin()</methodname> や <methodname>getMax()</methodname>
  1168. で設定内容を取得することもできます。
  1169. </para>
  1170. <example id="zend.file.transfer.validators.wordcount.example">
  1171. <title>WordCount バリデータの使用法</title>
  1172. <programlisting language="php"><![CDATA[
  1173. $upload = new Zend_File_Transfer();
  1174. // ファイル内の単語数を 2000 語までに制限します
  1175. $upload->addValidator('WordCount', false, 2000);
  1176. // ファイル内の単語数を最大 5000 語、最小 1000 語に制限します
  1177. $upload->addValidator('WordCount', false, array('min' => 1000, 'max' => 5000));
  1178. ]]></programlisting>
  1179. </example>
  1180. </sect2>
  1181. </sect1>
  1182. <!--
  1183. vim:se ts=4 sw=4 tw=80 et:
  1184. -->