Zend_Cache-Frontends.xml 44 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 17136 -->
  4. <sect1 id="zend.cache.frontends">
  5. <title><classname>Zend_Cache</classname> のフロントエンド</title>
  6. <sect2 id="zend.cache.frontends.core">
  7. <title>Zend_Cache_Core</title>
  8. <sect3 id="zend.cache.frontends.core.introduction">
  9. <title>導入</title>
  10. <para>
  11. <classname>Zend_Cache_Core</classname> は特別なフロントエンドであり、
  12. モジュールのコアに含まれています。これはキャッシュフロントエンドの
  13. 基本機能を実装したものであり、他のクラスによってオーバーライドされます。
  14. </para>
  15. <note><para>
  16. その他のフロントエンドクラスは、すべて <classname>Zend_Cache_Core</classname>
  17. を継承しており、以下で説明しているメソッドおよびオプションは
  18. 他のフロントエンドでも使用可能です。そのため、ここではこれらについての
  19. 詳しい説明は省略します。
  20. </para></note>
  21. </sect3>
  22. <sect3 id="zend.cache.frontends.core.options">
  23. <title>使用可能なオプション</title>
  24. <para>
  25. これらのオプションを、先の例で示したようにファクトリメソッドに渡します。
  26. </para>
  27. <table id="zend.cache.frontends.core.options.table">
  28. <title>Core フロントエンドのオプション</title>
  29. <tgroup cols="4">
  30. <thead>
  31. <row>
  32. <entry>オプション</entry>
  33. <entry>データ型</entry>
  34. <entry>デフォルト値</entry>
  35. <entry>説明</entry>
  36. </row>
  37. </thead>
  38. <tbody>
  39. <row>
  40. <entry><emphasis>caching</emphasis></entry>
  41. <entry><type>Boolean</type></entry>
  42. <entry><constant>TRUE</constant></entry>
  43. <entry>
  44. キャッシングを有効/無効にします
  45. (キャッシュされたスクリプトのデバッグ時に有用です)。
  46. </entry>
  47. </row>
  48. <row>
  49. <entry><emphasis>cache_id_prefix</emphasis></entry>
  50. <entry><type>String</type></entry>
  51. <entry><constant>NULL</constant></entry>
  52. <entry>
  53. すべてのキャッシュ ID のプレフィックス。<constant>NULL</constant> を指定すると、
  54. プレフィックスは使用しません。
  55. キャッシュ ID のプレフィックスは、いわばキャッシュ内での名前空間です。
  56. これによって、複数のアプリケーションやウェブサイトで
  57. キャッシュを共用できるようになります。
  58. 個々のアプリケーションやウェブサイトで
  59. それぞれ異なるキャッシュ ID プレフィックスを用いるようにすれば、
  60. 特定のキャッシュ ID をそれぞれの環境で使用できるようになります。
  61. </entry>
  62. </row>
  63. <row>
  64. <entry><emphasis>lifetime</emphasis></entry>
  65. <entry><type>Integer</type></entry>
  66. <entry>3600</entry>
  67. <entry>
  68. キャッシュの有効期間 (秒)。<constant>NULL</constant>
  69. を指定すると、有効期間が無期限となります。
  70. </entry>
  71. </row>
  72. <row>
  73. <entry><emphasis>logging</emphasis></entry>
  74. <entry><type>Boolean</type></entry>
  75. <entry><constant>FALSE</constant></entry>
  76. <entry>
  77. <constant>TRUE</constant> を指定すると、<classname>Zend_Log</classname> によるロギングが有効になります
  78. (しかし、処理速度は低下します)。
  79. </entry>
  80. </row>
  81. <row>
  82. <entry><emphasis>write_control</emphasis></entry>
  83. <entry><type>Boolean</type></entry>
  84. <entry><constant>TRUE</constant></entry>
  85. <entry>
  86. 書き込み制御を有効/無効にします (壊れたエントリを検出するため、
  87. 書き込んだ直後にそのキャッシュを読み込みます)。
  88. writeControl を有効にすると、キャッシュの書き込みがやや遅くなりますが、
  89. 読み込みの速度は変わりません
  90. (これはキャッシュファイルが壊れているかどうかを調べるものですが、
  91. 完全に判断できるわけではありません)。
  92. </entry>
  93. </row>
  94. <row>
  95. <entry><emphasis>automatic_serialization</emphasis></entry>
  96. <entry><type>Boolean</type></entry>
  97. <entry><constant>FALSE</constant></entry>
  98. <entry>
  99. 自動シリアライズを有効/無効にします。
  100. 文字列でないデータを直接保存する際に使用します
  101. (しかし、処理速度は低下します)。
  102. </entry>
  103. </row>
  104. <row>
  105. <entry><emphasis>automatic_cleaning_factor</emphasis></entry>
  106. <entry><type>Integer</type></entry>
  107. <entry>10</entry>
  108. <entry>
  109. 自動クリーンアッププロセス (ガベージコレクタ) の設定を行います。
  110. 0 を指定すると、自動キャッシュクリーニングを行いません。
  111. 1 を指定すると計画的にキャッシュのクリーニングを行い、また
  112. x (1 より大きな整数) を指定すると、
  113. x 回のキャッシュ書き込みについて 1 回の頻度で
  114. ランダムに自動クリーニングを行います。
  115. </entry>
  116. </row>
  117. <row>
  118. <entry><emphasis>ignore_user_abort</emphasis></entry>
  119. <entry><type>Boolean</type></entry>
  120. <entry><constant>FALSE</constant></entry>
  121. <entry>
  122. <constant>TRUE</constant> を指定すると、<methodname>save()</methodname> メソッド内で
  123. <acronym>PHP</acronym> の ignore_user_abort フラグを設定し、
  124. キャッシュが破壊されることを防ぎます。
  125. </entry>
  126. </row>
  127. </tbody>
  128. </tgroup>
  129. </table>
  130. </sect3>
  131. <sect3 id="zend.cache.core.examples">
  132. <title>例</title>
  133. <para>
  134. マニュアルのいちばんはじめのほうに、例を示しています。
  135. </para>
  136. <para>
  137. もしキャッシュに文字列しか保存しないのなら
  138. ("automatic_serialization" オプションを使用すると boolean も保存できるので)、
  139. このようにもう少しコンパクトに作成することが可能です。
  140. </para>
  141. <programlisting language="php"><![CDATA[
  142. // すでに $cache が存在するものとします
  143. $id = 'myBigLoop'; //「キャッシュしたい内容」のキャッシュ ID
  144. if (!($data = $cache->load($id))) {
  145. // キャッシュが存在しませんでした
  146. $data = '';
  147. for ($i = 0; $i < 10000; $i++) {
  148. $data = $data . $i;
  149. }
  150. $cache->save($data);
  151. }
  152. // [...] $data を用いて何かをします (echo したり、何かに渡したりなど)
  153. ]]></programlisting>
  154. <para>
  155. 複数のブロックやデータのインスタンスをキャッシュしたい場合も、考え方は同じです。
  156. </para>
  157. <programlisting language="php"><![CDATA[
  158. // 一意な ID を使用するようにしましょう
  159. $id1 = 'foo';
  160. $id2 = 'bar';
  161. // ブロック 1
  162. if (!($data = $cache->load($id1))) {
  163. // キャッシュが存在しませんでした
  164. $data = '';
  165. for ($i=0;$i<10000;$i++) {
  166. $data = $data . $i;
  167. }
  168. $cache->save($data);
  169. }
  170. echo($data);
  171. // これは、キャッシュ処理の影響を受けません
  172. echo('キャッシュされません !');
  173. // ブロック 2
  174. if (!($data = $cache->load($id2))) {
  175. // キャッシュが存在しませんでした
  176. $data = '';
  177. for ($i=0;$i<10000;$i++) {
  178. $data = $data . '!';
  179. }
  180. $cache->save($data);
  181. }
  182. echo($data);
  183. ]]></programlisting>
  184. <para>
  185. 特殊な値 (boolean 値に "automatic_serialization" オプションを指定したものなど)
  186. や空の文字列をキャッシュしたい場合は、
  187. 上で示したコンパクトな例を使用することはできません。
  188. キャッシュレコードを正式に調べる必要があります。
  189. </para>
  190. <programlisting language="php"><![CDATA[
  191. // コンパクトな構文
  192. // (空の文字列や boolean をキャッシュする場合はうまくいきません)
  193. if (!($data = $cache->load($id))) {
  194. // キャッシュが存在しませんでした
  195. // [...] $data を作成します
  196. $cache->save($data);
  197. }
  198. // $data に対して何らかの操作をします
  199. // [...]
  200. // 完全な構文 (どんな場合でも動作します)
  201. if (!($cache->test($id))) {
  202. // キャッシュが存在しませんでした
  203. // [...] $data を作成します
  204. $cache->save($data);
  205. } else {
  206. // キャッシュが見つかりました
  207. $data = $cache->load($id);
  208. }
  209. // $data に対して何らかの操作をします
  210. ]]></programlisting>
  211. </sect3>
  212. </sect2>
  213. <sect2 id="zend.cache.frontends.output">
  214. <title>Zend_Cache_Frontend_Output</title>
  215. <sect3 id="zend.cache.frontends.output.introduction">
  216. <title>導入</title>
  217. <para>
  218. <classname>Zend_Cache_Frontend_Output</classname> は、出力を横取りするフロントエンドです。
  219. これは <acronym>PHP</acronym> の出力バッファリング処理を使いやすくしたもので、
  220. <methodname>start()</methodname> メソッドと
  221. <methodname>end()</methodname> メソッドの間の出力を横取りします。
  222. </para>
  223. </sect3>
  224. <sect3 id="zend.cache.frontends.output.options">
  225. <title>使用可能なオプション</title>
  226. <para>
  227. <classname>Zend_Cache_Core</classname> のオプション以外に、
  228. このフロントエンドが独自に使用するオプションはありません。
  229. </para>
  230. </sect3>
  231. <sect3 id="zend.cache.frontends.output.examples">
  232. <title>例</title>
  233. <para>
  234. このマニュアルの冒頭に示した例とほとんど同じですが、少しだけ変更を加えています。
  235. </para>
  236. <programlisting language="php"><![CDATA[
  237. // キャッシュが見つからなかった場合に、出力バッファリングが起動します
  238. if (!($cache->start('mypage'))) {
  239. // すべてをいつもどおりに出力しますoutput everything as usual
  240. echo 'Hello world! ';
  241. echo 'これはキャッシュされます ('.time().') ';
  242. $cache->end(); // 出力バッファリングを終了します
  243. }
  244. echo 'これはキャッシュされません ('.time().').';
  245. ]]></programlisting>
  246. <para>
  247. この形式を使用すると、既存のプロジェクトに簡単に出力キャッシュ処理を追加することができます。
  248. コードのリファクタリングもほとんど行わずにすませられるでしょう。
  249. </para>
  250. </sect3>
  251. </sect2>
  252. <sect2 id="zend.cache.frontends.function">
  253. <title>Zend_Cache_Frontend_Function</title>
  254. <sect3 id="zend.cache.frontends.function.introduction">
  255. <title>導入</title>
  256. <para>
  257. <classname>Zend_Cache_Frontend_Function</classname> は、関数コールの結果をキャッシュします。
  258. <methodname>call()</methodname> というメソッドを保持しており、
  259. 関数名とパラメータを配列にしてこのメソッドに渡します。
  260. </para>
  261. </sect3>
  262. <sect3 id="zend.cache.frontends.function.options">
  263. <title>使用可能なオプション</title>
  264. <table id="zend.cache.frontends.function.options.table">
  265. <title>Function フロントエンドのオプション</title>
  266. <tgroup cols="4">
  267. <thead>
  268. <row>
  269. <entry>オプション</entry>
  270. <entry>データ型</entry>
  271. <entry>デフォルト値</entry>
  272. <entry>説明</entry>
  273. </row>
  274. </thead>
  275. <tbody>
  276. <row>
  277. <entry><emphasis>cache_by_default</emphasis></entry>
  278. <entry><type>Boolean</type></entry>
  279. <entry><constant>TRUE</constant></entry>
  280. <entry>
  281. <constant>TRUE</constant> の場合は、関数のコール結果がデフォルトでキャッシュされます。
  282. </entry>
  283. </row>
  284. <row>
  285. <entry><emphasis>cached_functions</emphasis></entry>
  286. <entry><type>Array</type></entry>
  287. <entry></entry>
  288. <entry>
  289. 常にキャッシュされる関数の名前。
  290. </entry>
  291. </row>
  292. <row>
  293. <entry><emphasis>non_cached_functions</emphasis></entry>
  294. <entry><type>Array</type></entry>
  295. <entry></entry>
  296. <entry>
  297. 決してキャッシュされない関数の名前。
  298. </entry>
  299. </row>
  300. </tbody>
  301. </tgroup>
  302. </table>
  303. </sect3>
  304. <sect3 id="zend.cache.frontends.function.examples">
  305. <title>例</title>
  306. <para>
  307. <methodname>call()</methodname> 関数の使用法は、<acronym>PHP</acronym> の
  308. <methodname>call_user_func_array()</methodname> と同じです。
  309. </para>
  310. <programlisting language="php"><![CDATA[
  311. $cache->call('veryExpensiveFunc', $params);
  312. // $params は配列です。
  313. // 例えば、veryExpensiveFunc(1, 'foo', 'bar') のコールをキャッシュするには
  314. // $cache->call('veryExpensiveFunc', array(1, 'foo', 'bar')) とします。
  315. ]]></programlisting>
  316. <para>
  317. <classname>Zend_Cache_Frontend_Function</classname> は、
  318. 関数の返り値だけでなく関数内部での出力もキャッシュします。
  319. </para>
  320. <note><para>
  321. <methodname>array()</methodname>、<methodname>echo()</methodname>、<methodname>empty()</methodname>、<methodname>eval()</methodname>、
  322. <methodname>exit()</methodname>、<methodname>isset()</methodname>、<methodname>list()</methodname>、<methodname>print()</methodname>
  323. および <methodname>unset()</methodname> 以外なら、
  324. 任意の組み込み関数やユーザ定義関数を渡すことができます。
  325. </para></note>
  326. </sect3>
  327. </sect2>
  328. <sect2 id="zend.cache.frontends.class">
  329. <title>Zend_Cache_Frontend_Class</title>
  330. <sect3 id="zend.cache.frontends.class.introduction">
  331. <title>導入</title>
  332. <para>
  333. <classname>Zend_Cache_Frontend_Class</classname> は、<classname>Zend_Cache_Frontend_Function</classname>
  334. と異なり、オブジェクトおよびスタティックメソッドのコールをキャッシュします。
  335. </para>
  336. </sect3>
  337. <sect3 id="zend.cache.frontends.class.options">
  338. <title>使用可能なオプション</title>
  339. <table id="zend.cache.frontends.class.options.table">
  340. <title>Class フロントエンドのオプション</title>
  341. <tgroup cols="4">
  342. <thead>
  343. <row>
  344. <entry>オプション</entry>
  345. <entry>データ型</entry>
  346. <entry>デフォルト値</entry>
  347. <entry>説明</entry>
  348. </row>
  349. </thead>
  350. <tbody>
  351. <row>
  352. <entry><emphasis>cached_entity</emphasis> (必須)</entry>
  353. <entry><type>Mixed</type></entry>
  354. <entry></entry>
  355. <entry>
  356. クラス名を設定すると、抽象クラスおよびスタティックコールをキャッシュします。
  357. オブジェクトを設定すると、そのオブジェクトのメソッドをキャッシュします。
  358. </entry>
  359. </row>
  360. <row>
  361. <entry><emphasis>cache_by_default</emphasis></entry>
  362. <entry><type>Boolean</type></entry>
  363. <entry><constant>TRUE</constant></entry>
  364. <entry>
  365. <constant>TRUE</constant> を設定すると、デフォルトでキャッシュされます。
  366. </entry>
  367. </row>
  368. <row>
  369. <entry><emphasis>cached_methods</emphasis></entry>
  370. <entry><type>Array</type></entry>
  371. <entry></entry>
  372. <entry>
  373. 常にキャッシュされるメソッドの名前。
  374. </entry>
  375. </row>
  376. <row>
  377. <entry><emphasis>non_cached_methods</emphasis></entry>
  378. <entry><type>Array</type></entry>
  379. <entry></entry>
  380. <entry>
  381. 決してキャッシュされないメソッドの名前。
  382. </entry>
  383. </row>
  384. </tbody>
  385. </tgroup>
  386. </table>
  387. </sect3>
  388. <sect3 id="zend.cache.frontends.class.examples">
  389. <title>例</title>
  390. <para>
  391. 例えば、スタティックメソッドのコールをキャッシュするには次のようにします。
  392. </para>
  393. <programlisting language="php"><![CDATA[
  394. class Test {
  395. // スタティックメソッド
  396. public static function foobar($param1, $param2) {
  397. echo "foobar_output($param1, $param2)";
  398. return "foobar_return($param1, $param2)";
  399. }
  400. }
  401. // [...]
  402. $frontendOptions = array(
  403. 'cached_entity' => 'Test' // クラス名を指定します
  404. );
  405. // [...]
  406. // これはキャッシュされます
  407. $result = $cache->foobar('1', '2');
  408. ]]></programlisting>
  409. <para>
  410. 通常のメソッドのコールをキャッシュするには次のようにします。
  411. </para>
  412. <programlisting language="php"><![CDATA[
  413. class Test {
  414. private $_string = 'hello !';
  415. public function foobar2($param1, $param2) {
  416. echo($this->_string);
  417. echo "foobar2_output($param1, $param2)";
  418. return "foobar2_return($param1, $param2)";
  419. }
  420. }
  421. // [...]
  422. $frontendOptions = array(
  423. 'cached_entity' => new Test() // クラスのインスタンスを指定します
  424. );
  425. // [...]
  426. // これはキャッシュされます
  427. $result = $cache->foobar2('1', '2');
  428. ]]></programlisting>
  429. </sect3>
  430. </sect2>
  431. <sect2 id="zend.cache.frontends.file">
  432. <title>Zend_Cache_Frontend_File</title>
  433. <sect3 id="zend.cache.frontends.file.introduction">
  434. <title>導入</title>
  435. <para>
  436. <classname>Zend_Cache_Frontend_File</classname> は、マスタファイルの
  437. 「更新時刻」にもとづいて動作するフロントエンドです。
  438. これは、例えば設定ファイルやテンプレートなどで有効に使えるでしょう。
  439. 複数のマスタファイルを使用することもできます。
  440. </para>
  441. <para>
  442. 例えば、<acronym>XML</acronym> の設定ファイルを使用しており、それが「設定オブジェクト」
  443. (<classname>Zend_Config</classname> など) を返す関数でパースされるとしましょう。
  444. <classname>Zend_Cache_Frontend_File</classname> を使用すると、その「設定オブジェクト」
  445. をキャッシュすることができ (これにより、
  446. <acronym>XML</acronym> ファイルを毎回パースする必要がなくなります)、さらに「マスタファイル」
  447. との間で強力な依存性を保持することができます。そのため、<acronym>XML</acronym>
  448. 設定ファイルが更新されると、即時にキャッシュが無効になります。
  449. </para>
  450. </sect3>
  451. <sect3 id="zend.cache.frontends.file.options">
  452. <title>使用可能なオプション</title>
  453. <table id="zend.cache.frontends.file.options.table">
  454. <title>File フロントエンドのオプション</title>
  455. <tgroup cols="4">
  456. <thead>
  457. <row>
  458. <entry>オプション</entry>
  459. <entry>データ型</entry>
  460. <entry>デフォルト値</entry>
  461. <entry>説明</entry>
  462. </row>
  463. </thead>
  464. <tbody>
  465. <row>
  466. <entry><emphasis>master_file (非推奨)</emphasis></entry>
  467. <entry><type>String</type></entry>
  468. <entry>''</entry>
  469. <entry>
  470. マスタファイルへのフルパス。
  471. </entry>
  472. </row>
  473. <row>
  474. <entry><emphasis>master_files</emphasis></entry>
  475. <entry><type>Array</type></entry>
  476. <entry><methodname>array()</methodname></entry>
  477. <entry>
  478. マスタファイル群へのフルパスの配列。
  479. </entry>
  480. </row>
  481. <row>
  482. <entry><emphasis>master_files_mode</emphasis></entry>
  483. <entry><type>String</type></entry>
  484. <entry><constant>Zend_Cache_Frontend_File::MODE_OR</constant></entry>
  485. <entry>
  486. <constant>Zend_Cache_Frontend_File::MODE_AND</constant> あるいは
  487. <constant>Zend_Cache_Frontend_File::MODE_OR</constant>。
  488. <constant>MODE_AND</constant> の場合は、
  489. すべてのマスタファイルにアクセスがあるまでキャッシュが無効化されません。
  490. <constant>MODE_OR</constant> の場合は、
  491. どれかひとつのマスタファイルにアクセスがあればキャッシュを無効化します。
  492. </entry>
  493. </row>
  494. <row>
  495. <entry><emphasis>ignore_missing_master_files</emphasis></entry>
  496. <entry><type>Boolean</type></entry>
  497. <entry><constant>FALSE</constant></entry>
  498. <entry>
  499. <constant>TRUE</constant> の場合は、マスタファイルが存在しない場合は無視します
  500. (それ以外の場合は例外が発生します)。
  501. </entry>
  502. </row>
  503. </tbody>
  504. </tgroup>
  505. </table>
  506. </sect3>
  507. <sect3 id="zend.cache.frontends.file.examples">
  508. <title>例</title>
  509. <para>
  510. このフロントエンドの使用法は <classname>Zend_Cache_Core</classname> と同じです。
  511. そのため、特に例は用意していません。唯一しなければならないことは、
  512. ファクトリを使用する際に、バックエンドのオプションとして
  513. <emphasis>master_file</emphasis> を設定することだけです。
  514. </para>
  515. </sect3>
  516. </sect2>
  517. <sect2 id="zend.cache.frontends.page">
  518. <title>Zend_Cache_Frontend_Page</title>
  519. <sect3 id="zend.cache.frontends.page.introduction">
  520. <title>導入</title>
  521. <para>
  522. <classname>Zend_Cache_Frontend_Page</classname> は <classname>Zend_Cache_Frontend_Output</classname>
  523. と似ていますが、ページ全体をキャッシュする目的で設計されています。
  524. <classname>Zend_Cache_Frontend_Page</classname> を使用して、
  525. ページの一部だけをキャッシュすることはできません。
  526. </para>
  527. <para>
  528. 一方、「キャッシュ ID」は自動的に生成されます。この ID は、
  529. <varname>$_SERVER['REQUEST_URI']</varname> および (オプションの設定によっては)
  530. <varname>$_GET</varname>、<varname>$_POST</varname>、<varname>$_SESSION</varname>、
  531. <varname>$_COOKIE</varname>、<varname>$_FILES</varname> をもとにして生成されます。
  532. さらに、ひとつのメソッド (<methodname>start()</methodname>) をコールするだけで使用できます。
  533. <methodname>end()</methodname> は、ページの終了時に自動的にコールされます。
  534. </para>
  535. <para>
  536. 現時点ではまだ実装されていませんが、将来は <acronym>HTTP</acronym> conditional システムを追加する予定です。
  537. これにより、ネットワークの帯域を節約できるようになります
  538. (キャッシュにヒットし、かつブラウザがそのバージョンを既に持っている場合に
  539. <acronym>HTTP</acronym> 304 Not Modified を送信するようにします)。
  540. </para>
  541. </sect3>
  542. <sect3 id="zend.cache.frontends.page.options">
  543. <title>使用可能なオプション</title>
  544. <table id="zend.cache.frontends.page.options.table">
  545. <title>Page フロントエンドのオプション</title>
  546. <tgroup cols="4">
  547. <thead>
  548. <row>
  549. <entry>オプション</entry>
  550. <entry>データ型</entry>
  551. <entry>デフォルト値</entry>
  552. <entry>説明</entry>
  553. </row>
  554. </thead>
  555. <tbody>
  556. <row>
  557. <entry><emphasis>http_conditional</emphasis></entry>
  558. <entry><type>Boolean</type></entry>
  559. <entry><constant>FALSE</constant></entry>
  560. <entry>
  561. http_conditional システムを使用します (現時点ではまだ実装されていません)。
  562. </entry>
  563. </row>
  564. <row>
  565. <entry><emphasis>debug_header</emphasis></entry>
  566. <entry><type>Boolean</type></entry>
  567. <entry><constant>FALSE</constant></entry>
  568. <entry>
  569. <constant>TRUE</constant> の場合は、キャッシュされた各ページの先頭に
  570. デバッグ用テキストが追加されます。
  571. </entry>
  572. </row>
  573. <row>
  574. <entry><emphasis>default_options</emphasis></entry>
  575. <entry><type>Array</type></entry>
  576. <entry><methodname>array(...説明を参照ください...)</methodname></entry>
  577. <entry>
  578. デフォルトのオプションを表す連想配列です。
  579. <itemizedlist>
  580. <listitem>
  581. <para>
  582. <emphasis>(boolean, デフォルトは <constant>TRUE</constant>) cache</emphasis> :
  583. <constant>TRUE</constant> の場合はキャッシュが有効になります。
  584. </para>
  585. </listitem>
  586. <listitem>
  587. <para>
  588. <emphasis>(boolean, デフォルトは <constant>FALSE</constant>) cache_with_get_variables</emphasis> :
  589. <constant>TRUE</constant> の場合は、<varname>$_GET</varname> 配列に変数が含まれていてもキャッシュがオンのままになります。
  590. </para>
  591. </listitem>
  592. <listitem>
  593. <para>
  594. <emphasis>(boolean, デフォルトは <constant>FALSE</constant>) cache_with_post_variables</emphasis> :
  595. <constant>TRUE</constant> の場合は、<varname>$_POST</varname> 配列に変数が含まれていてもキャッシュがオンのままになります。
  596. </para>
  597. </listitem>
  598. <listitem>
  599. <para>
  600. <emphasis>(boolean, デフォルトは <constant>FALSE</constant>) cache_with_session_variables</emphasis> :
  601. <constant>TRUE</constant> の場合は、<varname>$_SESSION</varname> 配列に変数が含まれていてもキャッシュがオンのままになります。
  602. </para>
  603. </listitem>
  604. <listitem>
  605. <para>
  606. <emphasis>(boolean, デフォルトは <constant>FALSE</constant>) cache_with_files_variables</emphasis> :
  607. <constant>TRUE</constant> の場合は、<varname>$_FILES</varname> 配列に変数が含まれていてもキャッシュがオンのままになります。
  608. </para>
  609. </listitem>
  610. <listitem>
  611. <para>
  612. <emphasis>(boolean, デフォルトは <constant>FALSE</constant>) cache_with_cookie_variables</emphasis> :
  613. <constant>TRUE</constant> の場合は、<varname>$_COOKIE</varname> 配列に変数が含まれていてもキャッシュがオンのままになります。
  614. </para>
  615. </listitem>
  616. <listitem>
  617. <para>
  618. <emphasis>(boolean, デフォルトは <constant>TRUE</constant>) make_id_with_get_variables</emphasis> :
  619. <constant>TRUE</constant> の場合は、キャッシュ ID が <varname>$_GET</varname> 配列の内容に依存するようになります。
  620. </para>
  621. </listitem>
  622. <listitem>
  623. <para>
  624. <emphasis>(boolean, デフォルトは <constant>TRUE</constant>) make_id_with_post_variables</emphasis> :
  625. <constant>TRUE</constant> の場合は、キャッシュ ID が <varname>$_POST</varname> 配列の内容に依存するようになります。
  626. </para>
  627. </listitem>
  628. <listitem>
  629. <para>
  630. <emphasis>(boolean, デフォルトは <constant>TRUE</constant>) make_id_with_session_variables</emphasis> :
  631. <constant>TRUE</constant> の場合は、キャッシュ ID が <varname>$_SESSION</varname> 配列の内容に依存するようになります。
  632. </para>
  633. </listitem>
  634. <listitem>
  635. <para>
  636. <emphasis>(boolean, デフォルトは <constant>TRUE</constant>) make_id_with_files_variables</emphasis> :
  637. <constant>TRUE</constant> の場合は、キャッシュ ID が <varname>$_FILES</varname> 配列の内容に依存するようになります。
  638. </para>
  639. </listitem>
  640. <listitem>
  641. <para>
  642. <emphasis>(boolean, デフォルトは <constant>TRUE</constant>) make_id_with_cookie_variables</emphasis> :
  643. <constant>TRUE</constant> の場合は、キャッシュ ID が <varname>$_COOKIE</varname> 配列の内容に依存するようになります。
  644. </para>
  645. </listitem>
  646. <listitem>
  647. <para>
  648. <emphasis>(int, デフォルトは <constant>FALSE</constant>) specific_lifetime</emphasis> :
  649. <constant>FALSE</constant> でない場合は、選択した正規表現に対して指定した有効期限を使用します。
  650. </para>
  651. </listitem>
  652. <listitem>
  653. <para>
  654. <emphasis>(配列, デフォルトは <methodname>array()</methodname>) tags</emphasis> :
  655. キャッシュレコード用のタグ。
  656. </para>
  657. </listitem>
  658. <listitem>
  659. <para>
  660. <emphasis>(int, デフォルトは <constant>NULL</constant>) priority</emphasis> :
  661. 優先度 (バックエンドが優先度をサポートしている場合)。
  662. </para>
  663. </listitem>
  664. </itemizedlist>
  665. </entry>
  666. </row>
  667. <row>
  668. <entry><emphasis>regexps</emphasis></entry>
  669. <entry><type>Array</type></entry>
  670. <entry><methodname>array()</methodname></entry>
  671. <entry>
  672. 特定の <constant>REQUEST_URI</constant> に対してのみ適用するオプションを設定する連想配列です。
  673. キーが (<acronym>PCRE</acronym> の) 正規表現、対応する値は連想配列となります。
  674. この連想配列には、正規表現が <varname>$_SERVER['REQUEST_URI']</varname>
  675. にマッチした場合に設定されるオプションを設定します
  676. (使用可能なオプションについては default_options を参照ください)。
  677. 複数の正規表現が <varname>$_SERVER['REQUEST_URI']</varname> にマッチした場合は、
  678. 一番最後にマッチしたもののみが使用されます。
  679. </entry>
  680. </row>
  681. <row>
  682. <entry><emphasis>memorize_headers</emphasis></entry>
  683. <entry><type>Array</type></entry>
  684. <entry><methodname>array()</methodname></entry>
  685. <entry>
  686. <acronym>HTTP</acronym> ヘッダ名に対応する文字列の配列です。
  687. ここにあげられたヘッダがキャッシュデータとともに保存され、
  688. キャッシュにヒットしたときにそれが "リプレイ" されます。
  689. </entry>
  690. </row>
  691. </tbody>
  692. </tgroup>
  693. </table>
  694. </sect3>
  695. <sect3 id="zend.cache.frontends.page.examples">
  696. <title>例</title>
  697. <para>
  698. <classname>Zend_Cache_Frontend_Page</classname> の使用法は、きわめて簡単です。
  699. </para>
  700. <programlisting language="php"><![CDATA[
  701. // [...] // require、設定そしてファクトリ
  702. $cache->start();
  703. // キャッシュにヒットした場合はその結果がブラウザに送信され、
  704. // 処理はここで停止します
  705. // ページの残りの部分 ...
  706. ]]></programlisting>
  707. <para>
  708. もう少し複雑な例を見てみましょう。これは、起動ファイル
  709. (例えば <classname>Zend_Controller</classname> など) 内でキャッシュを集中管理する方法を示したものです。
  710. </para>
  711. <programlisting language="php"><![CDATA[
  712. /*
  713. * キャッシュセクションの前には、あまり多くの行を書かないようにしましょう。
  714. * 例えば、処理速度を最適化するためには "require_once" や "Zend_Loader::loadClass"
  715. * をキャッシュセクションの後におくべきです。
  716. */
  717. $frontendOptions = array(
  718. 'lifetime' => 7200,
  719. 'debug_header' => true, // デバッグします
  720. 'regexps' => array(
  721. // IndexController 全体をキャッシュします
  722. '^/$' => array('cache' => true),
  723. // IndexController 全体をキャッシュします
  724. '^/index/' => array('cache' => true),
  725. // ArticleController はキャッシュしません
  726. '^/article/' => array('cache' => false),
  727. // ……が、ArticleController の "view" アクションはキャッシュします
  728. '^/article/view/' => array(
  729. 'cache' => true,
  730. // また、たとえ $_POST に何らかの変数がふくまれていてもキャッシュを行います
  731. 'cache_with_post_variables' => true,
  732. // しかし、そのキャッシュは $_POST 配列に依存します
  733. 'make_id_with_post_variables' => true
  734. )
  735. )
  736. );
  737. $backendOptions = array(
  738. 'cache_dir' => '/tmp/'
  739. );
  740. // Zend_Cache_Frontend_Page オブジェクトを取得します
  741. $cache = Zend_Cache::factory('Page',
  742. 'File',
  743. $frontendOptions,
  744. $backendOptions);
  745. $cache->start();
  746. // キャッシュにヒットした場合はその結果がブラウザに送信され、スクリプトの処理はここで停止します。
  747. // [...] 起動ファイルの終点 (これらの行は、キャッシュにヒットした場合は実行されません)
  748. ]]></programlisting>
  749. </sect3>
  750. <sect3 id="zend.cache.frontends.page.cancel">
  751. <title>キャンセル用のメソッド</title>
  752. <para>
  753. 設計上の理由から、場合によっては (<acronym>HTTP</acronym> 200 以外のコードを使用する場合など)
  754. 現在のキャッシュ処理をキャンセルする必要が生じることもあります。
  755. そこで、このフロントエンド用に <methodname>cancel()</methodname> メソッドを用意しました。
  756. </para>
  757. <programlisting language="php"><![CDATA[
  758. // [...] // require, configuration そして factory
  759. $cache->start();
  760. // [...]
  761. if ($someTest) {
  762. $cache->cancel();
  763. // [...]
  764. }
  765. // [...]
  766. ]]></programlisting>
  767. </sect3>
  768. </sect2>
  769. </sect1>
  770. <!--
  771. vim:se ts=4 sw=4 et:
  772. -->