Zend_Cache-Frontends.xml 39 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15103 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.cache.frontends">
  5. <title>Zend_Cache Frontends</title>
  6. <sect2 id="zend.cache.frontends.core">
  7. <title><classname>Zend_Cache_Core</classname></title>
  8. <sect3 id="zend.cache.frontends.core.introduction">
  9. <title>Einführung</title>
  10. <para>
  11. <classname>Zend_Cache_Core</classname> ist ein spezielles Frontend, da es der Kern dieses Moduls ist.
  12. Es ist ein generelles Cache Frontend und wurde von anderen Klassen erweitert.
  13. </para>
  14. <note>
  15. <para>
  16. Alle Frontends sind von <classname>Zend_Cache_Core</classname> abgeleitet, so dass deren Methoden und
  17. Optionen (wie folgt beschrieben) auch in anderen Frontends vorhanden sind. Deswegen werden
  18. sie dort nicht dokumentiert.
  19. </para>
  20. </note>
  21. </sect3>
  22. <sect3 id="zend.cache.frontends.core.options">
  23. <title>Mögliche Optionen</title>
  24. <para>
  25. Diese Optionen werden der Factory Methode übergeben wie im nachfolgenden Beispiel demonstriert.
  26. </para>
  27. <table id="zend.cache.frontends.core.options.table">
  28. <title>Core Frontend Optionen</title>
  29. <tgroup cols="4">
  30. <thead>
  31. <row>
  32. <entry>Option</entry>
  33. <entry>Daten Typ</entry>
  34. <entry>Standardwert</entry>
  35. <entry>Beschreibung</entry>
  36. </row>
  37. </thead>
  38. <tbody>
  39. <row>
  40. <entry><code>caching</code></entry>
  41. <entry><code>boolean</code></entry>
  42. <entry><code>true</code></entry>
  43. <entry>
  44. Ein- / Ausschalten vom Caching (kann sehr nützlich für das
  45. Debuggen von gecachten Skripten sein)
  46. </entry>
  47. </row>
  48. <row>
  49. <entry><code>cache_id_prefix</code></entry>
  50. <entry><code>string</code></entry>
  51. <entry><code>null</code></entry>
  52. <entry>
  53. Ein Präfix für alle Cache IDs. Wenn er auf <code>null</code>
  54. gesetzt wird, wird kein Cache ID Präfix verwendet. Der Cache ID
  55. Präfix erstellt grundsätzlich einen Namespace im Cache, der
  56. verschiedenen Anwendungen oder Websites die Verwendung eines
  57. gemeinsamen Caches erlaubt. Jede Anwendung oder Website kann
  58. einen anderen Cache ID Prüfix verwenden sodas spezielle Cache IDs
  59. mehr als einmal verwendet werden können.
  60. </entry>
  61. </row>
  62. <row>
  63. <entry><code>lifetime</code></entry>
  64. <entry><code>int</code></entry>
  65. <entry><code>3600</code></entry>
  66. <entry>
  67. Cache Lebensdauer (in Sekunden), wenn auf <code>null</code> gesetzt, ist
  68. der Cache für immer gültig.
  69. </entry>
  70. </row>
  71. <row>
  72. <entry><code>logging</code></entry>
  73. <entry><code>boolean</code></entry>
  74. <entry><code>false</code></entry>
  75. <entry>
  76. Wenn auf true gesetzt, wird das Logging durch <classname>Zend_Log</classname> aktiviert
  77. (aber das System wird langsamer)
  78. </entry>
  79. </row>
  80. <row>
  81. <entry><code>write_control</code></entry>
  82. <entry><code>boolean</code></entry>
  83. <entry><code>true</code></entry>
  84. <entry>
  85. Ein- / Ausschalten der Schreibkontrolle (der Cache wird gleich gelesen, nachdem
  86. er geschrieben wurde, um fehlerhafte Einträge zu finden); das Einschalten der
  87. Schreibkontrolle wird das Schreiben des Caches etwas verlangsamen, aber nicht das
  88. Lesen des Caches (es können defekte Cache Dateien entdeckt werden, aber es ist
  89. keine perfekte Kontrolle)
  90. </entry>
  91. </row>
  92. <row>
  93. <entry><code>automatic_serialization</code></entry>
  94. <entry><code>boolean</code></entry>
  95. <entry><code>false</code></entry>
  96. <entry>
  97. Ein- / Ausschalten der automatischen Serialisierung, kann dafür benutzt werden, um
  98. Daten direkt zu speichern, welche keine Strings sind (aber es ist langsamer)
  99. </entry>
  100. </row>
  101. <row>
  102. <entry><code>automatic_cleaning_factor</code></entry>
  103. <entry><code>int</code></entry>
  104. <entry><code>10</code></entry>
  105. <entry>
  106. Ausschalten / Abgleichen des automatischen Löschprozesses (Garbage Collector):
  107. 0 heißt keine automatische Löschung des Caches, 1 heißt Systematische Cache
  108. Löschung und x &gt; 1 heißt automatisches zufälliges Löschen 1 mal nach
  109. x Schreiboperationen.
  110. </entry>
  111. </row>
  112. <row>
  113. <entry><code>ignore_user_abort</code></entry>
  114. <entry><code>boolean</code></entry>
  115. <entry><code>false</code></entry>
  116. <entry>
  117. Auf true gesetzt, wird der Kern das PHP Flag ignore_user_abort innerhalb der
  118. save() Methode setzen um Cache Korruption in einigen fällen zuverhindern
  119. </entry>
  120. </row>
  121. </tbody>
  122. </tgroup>
  123. </table>
  124. </sect3>
  125. <sect3 id="zend.cache.core.examples">
  126. <title>Beispiele</title>
  127. <para>
  128. Ein Beispiel wird ganz am Anfang des Handbuches gegeben.
  129. </para>
  130. <para>
  131. Wenn nur Strings in den Cache gespeichert werden (denn mit der "automatic_serialization" Option
  132. wäre es möglich Booleans zu speichern), kann ein kompakterer Weg wie folgt gewählt werden:
  133. </para>
  134. <programlisting role="php"><![CDATA[
  135. // Es wird angenommen das $cache existiert
  136. $id = 'myBigLoop'; // Die Cache ID von dem "das gecached werden soll"
  137. if (!($data = $cache->load($id))) {
  138. // Cache miss
  139. $data = '';
  140. for ($i = 0; $i < 10000; $i++) {
  141. $data = $data . $i;
  142. }
  143. $cache->save($data);
  144. }
  145. // [...] Irgendwas mit $data machen (ausgeben, verarbeiten, usw.)
  146. ]]>
  147. </programlisting>
  148. <para>
  149. Wenn mehrere Blöcke von Daten oder Daten Instanzen gecached werden sollen, ist die
  150. Idee dahinter die gleiche:
  151. </para>
  152. <programlisting role="php"><![CDATA[
  153. // Sicherstellen, dass eindeutige Identifizierer verwendet werden:
  154. $id1 = 'foo';
  155. $id2 = 'bar';
  156. // Block 1
  157. if (!($data = $cache->load($id1))) {
  158. // Cache miss
  159. $data = '';
  160. for ($i=0;$i<10000;$i++) {
  161. $data = $data . $i;
  162. }
  163. $cache->save($data);
  164. }
  165. echo($data);
  166. // Hier wird NIE gecached
  167. echo('NIE GECACHED! ');
  168. // Block 2
  169. if (!($data = $cache->load($id2))) {
  170. // Cache miss
  171. $data = '';
  172. for ($i=0;$i<10000;$i++) {
  173. $data = $data . '!';
  174. }
  175. $cache->save($data);
  176. }
  177. echo($data);
  178. ]]>
  179. </programlisting>
  180. <para>
  181. Wenn spezielle Werte gecached werden sollen (boolean mit der "automatic_serialization" Option)
  182. oder leere Strings kann die kompakte Erstellung wie oben gezeigt nicht verwendet werden.
  183. Der Cache Eintrag muß formell getestet werden.
  184. </para>
  185. <programlisting role="php"><![CDATA[
  186. // Die kompakte Erstellung
  187. // (nicht gut wenn leere Strings und/oder boolsche Werte gecached werden)
  188. if (!($data = $cache->load($id))) {
  189. // Cache fehlgeschlagen
  190. // [...] wir erstellen $data
  191. $cache->save($data);
  192. }
  193. // wir machen etwas mit $data
  194. // [...]
  195. // die komplette Erstellung (funktioniert in jedem Fall)
  196. if (!($cache->test($id))) {
  197. // Cache fehlgeschlagen
  198. // [...] wir erstellen $data
  199. $cache->save($data);
  200. } else {
  201. // Cache getroffen
  202. $data = $cache->load($id);
  203. }
  204. // Wir machen irgendetwas mit $data
  205. ]]>
  206. </programlisting>
  207. </sect3>
  208. </sect2>
  209. <sect2 id="zend.cache.frontends.output">
  210. <title><classname>Zend_Cache_Frontend_Output</classname></title>
  211. <sect3 id="zend.cache.frontends.output.introduction">
  212. <title>Einführung</title>
  213. <para>
  214. <classname>Zend_Cache_Frontend_Output</classname> ist ein Ausgabe-Empfangendes Frontend. Es verwendet den
  215. Ausgabe Puffer in PHP, um alles zwischen der <code>start()</code> und der <code>end()</code> Methode
  216. zu fangen.
  217. </para>
  218. </sect3>
  219. <sect3 id="zend.cache.frontends.output.options">
  220. <title>Mögliche Optionen</title>
  221. <para>
  222. Dieses Frontend hat keine bestimmten Optionen zusätzlich zu denen von
  223. <classname>Zend_Cache_Core</classname>.
  224. </para>
  225. </sect3>
  226. <sect3 id="zend.cache.frontends.output.examples">
  227. <title>Beispiele</title>
  228. <para>
  229. Ein Beispiel wird ganz am Anfang des Handbuches gegeben. Hier ist es mit kleinen Änderungen:
  230. </para>
  231. <programlisting role="php"><![CDATA[
  232. // Wenn es ein Cache Miss ist, wird das puffern der Ausgabe ausgelöst
  233. if( ! ($cache->start('mypage'))) {
  234. // Alle wie gewohnt ausgeben
  235. echo 'Hallo Welt! ';
  236. echo 'Das wird gecached ('.time().') ';
  237. $cache->end(); // Ausgabepufferung beenden
  238. }
  239. echo 'Hier wird nie gecached ('.time().').';
  240. ]]>
  241. </programlisting>
  242. <para>
  243. Die Verwendung dieser Form ist ziemlich einfach, um Ausgabe caching in einem bereits bestehenden
  244. Projekt, mit nur wenig oder gar keinen Codeänderungen, zu erhalten.
  245. </para>
  246. </sect3>
  247. </sect2>
  248. <sect2 id="zend.cache.frontends.function">
  249. <title><classname>Zend_Cache_Frontend_Function</classname></title>
  250. <sect3 id="zend.cache.frontends.function.introduction">
  251. <title>Einführung</title>
  252. <para>
  253. <classname>Zend_Cache_Frontend_Function</classname> cached das Ergebnis von Funktionsaufrufen. Es hat
  254. eine einzelne Hauptmethode genannt <code>call()</code>, welche den Funktionsnamen und Parameter
  255. für den Aufruf in einem Array entgegennimmt.
  256. </para>
  257. </sect3>
  258. <sect3 id="zend.cache.frontends.function.options">
  259. <title>Mögliche Optionen</title>
  260. <table id="zend.cache.frontends.function.options.table">
  261. <title>Cache Frontend Optionen</title>
  262. <tgroup cols="4">
  263. <thead>
  264. <row>
  265. <entry>Option</entry>
  266. <entry>Daten Typ</entry>
  267. <entry>Standardwert</entry>
  268. <entry>Beschreibung</entry>
  269. </row>
  270. </thead>
  271. <tbody>
  272. <row>
  273. <entry><code>cache_by_default</code></entry>
  274. <entry><code>boolean</code></entry>
  275. <entry><code>true</code></entry>
  276. <entry>
  277. Wenn true, wird der Funktionsaufruf standardmäßig gecached
  278. </entry>
  279. </row>
  280. <row>
  281. <entry><code>cached_functions</code></entry>
  282. <entry><code>array</code></entry>
  283. <entry></entry>
  284. <entry>
  285. Funktionsnamen, die immer gecached werden sollen
  286. </entry>
  287. </row>
  288. <row>
  289. <entry><code>non_cached_functions</code></entry>
  290. <entry><code>array</code></entry>
  291. <entry></entry>
  292. <entry>
  293. Funktionsnamen, die nie gecached werden sollen
  294. </entry>
  295. </row>
  296. </tbody>
  297. </tgroup>
  298. </table>
  299. </sect3>
  300. <sect3 id="zend.cache.frontends.function.examples">
  301. <title>Beispiele</title>
  302. <para>
  303. Die Verwendung der <code>call()</code> Funktion ist die gleiche, wie die von
  304. <code>call_user_func_array()</code> in PHP:
  305. </para>
  306. <programlisting role="php"><![CDATA[
  307. $cache->call('veryExpensiveFunc', $params);
  308. // $params ist ein Array
  309. // Für das Aufrufen von veryExpensiveFunc(1, 'foo', 'bar') mit Caching kann,
  310. // z.B. $cache->call('veryExpensiveFunc', array(1, 'foo', 'bar')) benutzt
  311. // werden
  312. ]]>
  313. </programlisting>
  314. <para>
  315. <classname>Zend_Cache_Frontend_Function</classname> ist elegant genug, um beides zu cachen, den
  316. Rückgabewert der Funktion und deren interne Ausgabe.
  317. </para>
  318. <note><para>
  319. Man kann jede eingebaute oder benutzerdefinierte Funktion übergeben, mit ausnahme von
  320. <code>array()</code>, <code>echo()</code>, <code>empty()</code>, <code>eval()</code>,
  321. <code>exit()</code>, <code>isset()</code>, <code>list()</code>, <code>print()</code>
  322. und <code>unset()</code>.
  323. </para></note>
  324. </sect3>
  325. </sect2>
  326. <sect2 id="zend.cache.frontends.class">
  327. <title><classname>Zend_Cache_Frontend_Class</classname></title>
  328. <sect3 id="zend.cache.frontends.class.introduction">
  329. <title>Einführung</title>
  330. <para>
  331. <classname>Zend_Cache_Frontend_Class</classname> ist unterschiedlich zu <classname>Zend_Cache_Frontend_Function</classname>,
  332. weil es das Cachen von Objekten und statischen Methodenaufrufen erlaubt.
  333. </para>
  334. </sect3>
  335. <sect3 id="zend.cache.frontends.class.options">
  336. <title>Mögliche Optionen</title>
  337. <table id="zend.cache.frontends.class.options.table">
  338. <title>Class Frontend Optionen</title>
  339. <tgroup cols="4">
  340. <thead>
  341. <row>
  342. <entry>Option</entry>
  343. <entry>Datentyp</entry>
  344. <entry>Standardwert</entry>
  345. <entry>Beschreibung</entry>
  346. </row>
  347. </thead>
  348. <tbody>
  349. <row>
  350. <entry><code>cached_entity</code> (Notwendig)</entry>
  351. <entry><code>mixed</code></entry>
  352. <entry></entry>
  353. <entry>
  354. Wenn auf einen Klassennamen gesetzt, wird eine abstrakte Klasse gecached und
  355. es werden statische Aufrufe verwendet; wenn auf ein Objekt gesetzt, wird deren
  356. Objektmethoden gecached
  357. </entry>
  358. </row>
  359. <row>
  360. <entry><code>cache_by_default</code></entry>
  361. <entry><code>boolean</code></entry>
  362. <entry><code>true</code></entry>
  363. <entry>
  364. Wenn true, wird der Aufruf standardmäßig gecached
  365. </entry>
  366. </row>
  367. <row>
  368. <entry><code>cached_methods</code></entry>
  369. <entry><code>array</code></entry>
  370. <entry></entry>
  371. <entry>
  372. Methodennamen, die immer gecached werden sollen
  373. </entry>
  374. </row>
  375. <row>
  376. <entry><code>non_cached_methods</code></entry>
  377. <entry><code>array</code></entry>
  378. <entry></entry>
  379. <entry>
  380. Methodennamen, die nie gecached werden sollen
  381. </entry>
  382. </row>
  383. </tbody>
  384. </tgroup>
  385. </table>
  386. </sect3>
  387. <sect3 id="zend.cache.frontends.class.examples">
  388. <title>Beispiele</title>
  389. <para>
  390. zum Beispiel, um einen statischen Aufruf zu cachen:
  391. </para>
  392. <programlisting role="php"><![CDATA[
  393. class Test {
  394. // Statische Methode
  395. public static function foobar($param1, $param2) {
  396. echo "foobar_output($param1, $param2)";
  397. return "foobar_return($param1, $param2)";
  398. }
  399. }
  400. // [...]
  401. $frontendOptions = array(
  402. 'cached_entity' => 'Test' // Der Name der Klasse
  403. );
  404. // [...]
  405. // Der gecachte Aufruf
  406. $result = $cache->foobar('1', '2');
  407. ]]>
  408. </programlisting>
  409. <para>
  410. Um klassische Methodenaufrufe zu cachen :
  411. </para>
  412. <programlisting role="php"><![CDATA[
  413. class Test {
  414. private $_string = 'Hallo !';
  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() // Eine Instanz der Klasse
  424. );
  425. // [...]
  426. // Der gecachte Aufruf
  427. $res = $cache->foobar2('1', '2');
  428. ]]>
  429. </programlisting>
  430. </sect3>
  431. </sect2>
  432. <sect2 id="zend.cache.frontends.file">
  433. <title><classname>Zend_Cache_Frontend_File</classname></title>
  434. <sect3 id="zend.cache.frontends.file.introduction">
  435. <title>Einführung</title>
  436. <para>
  437. <classname>Zend_Cache_Frontend_File</classname> ist ein Frontend angetrieben durch den
  438. Änderungszeitpunkt einer "Masterdatei". Es ist wirklich interessant für Beispiele
  439. in Konfigurations- oder Templateanwendungen. Es ist auch möglich mehrere Masterdateien
  440. zu verwenden.
  441. </para>
  442. <para>
  443. Zum Beispiel eine XML Konfigurationsdatei, welche von einer Funktion geparsed wird
  444. und die ein "Config Objekt" zurückgibt (wie durch <classname>Zend_Config</classname>). Mit
  445. <classname>Zend_Cache_Frontend_File</classname> kann das "Config Objekt" im Cache gespeichert
  446. werden (um zu Verhindern, das die XML Konfiguration jedes mal geparsed wird), aber mit
  447. einer strengen Abhängigkeit zur "Masterdatei". Wenn also die XML Konfigurationsdatei
  448. geändert wird, wird der Cache sofort ungültig.
  449. </para>
  450. </sect3>
  451. <sect3 id="zend.cache.frontends.file.options">
  452. <title>Mögliche Optionen</title>
  453. <table id="zend.cache.frontends.file.options.table">
  454. <title>File Frontend Optionen</title>
  455. <tgroup cols="4">
  456. <thead>
  457. <row>
  458. <entry>Option</entry>
  459. <entry>Daten Typ</entry>
  460. <entry>Standardwert</entry>
  461. <entry>Beschreibung</entry>
  462. </row>
  463. </thead>
  464. <tbody>
  465. <row>
  466. <entry><code>master_File (depreciated)</code></entry>
  467. <entry><code>string</code></entry>
  468. <entry><code></code></entry>
  469. <entry>
  470. Der komplette Pfad und Name der Master Datei
  471. </entry>
  472. </row>
  473. <row>
  474. <entry><code>master_files</code></entry>
  475. <entry><code>array</code></entry>
  476. <entry><code></code></entry>
  477. <entry>
  478. Ein Array der kompletten Pfade der Masterdateien
  479. </entry>
  480. </row>
  481. <row>
  482. <entry><code>master_files_mode</code></entry>
  483. <entry><code>string</code></entry>
  484. <entry><classname>Zend_Cache_Frontend_File::MODE_OR</classname></entry>
  485. <entry>
  486. <classname>Zend_Cache_Frontend_File::MODE_AND</classname> oder
  487. <classname>Zend_Cache_Frontend_File::MODE_OR</classname> ;
  488. bei <code>MODE_AND</code> müssen alle Masterdateien angegriffen werden um einen
  489. Cache ungültig zu machen, bei <code>MODE_OR</code> ist eine eizelne angegriffene
  490. Datei genug um den Cache ungültig zu machen
  491. </entry>
  492. </row>
  493. <row>
  494. <entry><code>ignore_missing_master_files</code></entry>
  495. <entry><code>boolean</code></entry>
  496. <entry><code>false</code></entry>
  497. <entry>
  498. bei true werden fehlende Masterdateien leise ignoriert (andernfalls wird eine
  499. Exception geworfen)
  500. </entry>
  501. </row>
  502. </tbody>
  503. </tgroup>
  504. </table>
  505. </sect3>
  506. <sect3 id="zend.cache.frontends.file.examples">
  507. <title>Beispiele</title>
  508. <para>
  509. Die Verwendung dieses Frontends ist die gleiche wie die von <classname>Zend_Cache_Core</classname>.
  510. Es gibt kein eigenes Beispiel - was als einziges gemacht werden muß, ist das <code>master_File</code>
  511. zu definieren, wenn die Factory verwendet wird.
  512. </para>
  513. </sect3>
  514. </sect2>
  515. <sect2 id="zend.cache.frontends.page">
  516. <title><classname>Zend_Cache_Frontend_Page</classname></title>
  517. <sect3 id="zend.cache.frontends.page.introduction">
  518. <title>Einführung</title>
  519. <para>
  520. <classname>Zend_Cache_Frontend_Page</classname> ist wie <classname>Zend_Cache_Frontend_Output</classname>
  521. aber entwickelt für eine komplette Seite. Es ist unmöglich <classname>Zend_Cache_Frontend_Page</classname>
  522. nur für das Cachen eines einzelnen Blockes zu verwenden.
  523. </para>
  524. <para>
  525. Andererseits wird die "Cache ID" automatisch berechnet mit <code>$_SERVER['REQUEST_URI']</code> und
  526. (abhängig von den Optionen) mit
  527. <code>$_GET</code>, <code>$_POST</code>, <code>$_SESSION</code>, <code>$_COOKIE</code>, <code>$_FILES</code>.
  528. Trotzdem muß nur eine Methode aufgerufen werden (<code>start()</code>), weil der Aufruf von
  529. <code>end()</code> immer vollautomatisch ist, wenn die Seite endet.
  530. </para>
  531. <para>
  532. Zur Zeit ist es nicht eingebaut, aber es ist ein HTTP abhängiges System geplant, um Bandbreiten zu
  533. sparen (das System wird ein "HTTP 304 nicht geändert" schicken, wenn der Cache gefunden wurde und wenn
  534. der Browser bereits eine gültige Version hat).
  535. </para>
  536. </sect3>
  537. <sect3 id="zend.cache.frontends.page.options">
  538. <title>Mögliche Optionen</title>
  539. <table id="zend.cache.frontends.page.options.table">
  540. <title>Page Frontend Optionen</title>
  541. <tgroup cols="4">
  542. <thead>
  543. <row>
  544. <entry>Option</entry>
  545. <entry>Daten Typ</entry>
  546. <entry>Standardwert</entry>
  547. <entry>Beschreibung</entry>
  548. </row>
  549. </thead>
  550. <tbody>
  551. <row>
  552. <entry><code>http_conditional</code></entry>
  553. <entry><code>boolean</code></entry>
  554. <entry><code>false</code></entry>
  555. <entry>
  556. Verwendung des http_conditional Systems (zur Zeit nicht implementiert)
  557. </entry>
  558. </row>
  559. <row>
  560. <entry><code>debug_header</code></entry>
  561. <entry><code>boolean</code></entry>
  562. <entry><code>false</code></entry>
  563. <entry>
  564. Wenn true, wird eine Debugging Text for jeder gecacheten Seite hinzugefügt
  565. </entry>
  566. </row>
  567. <row>
  568. <entry><code>default_options</code></entry>
  569. <entry><code>array</code></entry>
  570. <entry><code>array(...siehe unten...)</code></entry>
  571. <entry>
  572. Ein assoziatives Array mit Default Optionen:
  573. <itemizedlist>
  574. <listitem>
  575. <para>
  576. <code>(boolean, true per Default) cache</code> :
  577. Cache ist aktiviert wenn true
  578. </para>
  579. </listitem>
  580. <listitem>
  581. <para>
  582. <code>(boolean, false per Default) cache_with_get_variables</code> :
  583. wenn true, ist der Cache weiterhin aktiviert, selbst wenn es
  584. einige Variables im <code>$_GET</code> Array gibt
  585. </para>
  586. </listitem>
  587. <listitem>
  588. <para>
  589. <code>(boolean, false per Default) cache_with_post_variables</code> :
  590. wenn true, ist der Cache weiterhin aktiviert, selbst wenn es
  591. einige Variables im <code>$_POST</code> Array gibt
  592. </para>
  593. </listitem>
  594. <listitem>
  595. <para>
  596. <code>(boolean, false per Default) cache_with_session_variables</code> :
  597. wenn true, ist der Cache weiterhin aktiviert, selbst wenn es
  598. einige Variables im <code>$_SESSION</code> Array gibt
  599. </para>
  600. </listitem>
  601. <listitem>
  602. <para>
  603. <code>(boolean, false per Default) cache_with_files_variables</code> :
  604. wenn true, ist der Cache weiterhin aktiviert, selbst wenn es
  605. einige Variables im <code>$_FILES</code> Array gibt
  606. </para>
  607. </listitem>
  608. <listitem>
  609. <para>
  610. <code>(boolean, false per Default) cache_with_cookie_variables</code> :
  611. wenn true, ist der Cache weiterhin aktiviert, selbst wenn es
  612. einige Variables im <code>$_COOKIE</code> Array gibt
  613. </para>
  614. </listitem>
  615. <listitem>
  616. <para>
  617. <code>(boolean, true per Default) make_id_with_get_variables</code> :
  618. wenn true, wird die Cache ID vom Inhalt des <code>$_GET</code>
  619. Arrays abhängig sein
  620. </para>
  621. </listitem>
  622. <listitem>
  623. <para>
  624. <code>(boolean, true per Default) make_id_with_post_variables</code> :
  625. wenn true, wird die Cache ID vom Inhalt des <code>$_POST</code>
  626. Arrays abhängig sein
  627. </para>
  628. </listitem>
  629. <listitem>
  630. <para>
  631. <code>(boolean, true per Default) make_id_with_session_variables</code> :
  632. wenn true, wird die Cache ID vom Inhalt des <code>$_SESSION</code>
  633. Arrays abhängig sein
  634. </para>
  635. </listitem>
  636. <listitem>
  637. <para>
  638. <code>(boolean, true per Default) make_id_with_files_variables</code> :
  639. wenn true, wird die Cache ID vom Inhalt des <code>$_FILES</code>
  640. Arrays abhängig sein
  641. </para>
  642. </listitem>
  643. <listitem>
  644. <para>
  645. <code>(boolean, true per Default) make_id_with_cookie_variables</code> :
  646. wenn true, wird die Cache ID vom Inhalt des <code>$_COOKIE</code>
  647. Arrays abhängig sein
  648. </para>
  649. </listitem>
  650. <listitem>
  651. <para>
  652. <code>(int, false by default) specific_lifetime</code> :
  653. wenn nicht false, wird die angegebene Lifetime für das ausgewählte
  654. Regex verwendet
  655. </para>
  656. </listitem>
  657. <listitem>
  658. <para>
  659. <code>(array, array() by default) tags</code> : Tags für den
  660. Cache Eintrag
  661. </para>
  662. </listitem>
  663. <listitem>
  664. <para>
  665. <code>(int, null by default) priority</code> : Priorität
  666. (wenn das Backend das unterstützt)
  667. </para>
  668. </listitem>
  669. </itemizedlist>
  670. </entry>
  671. </row>
  672. <row>
  673. <entry><code>regexps</code></entry>
  674. <entry><code>array</code></entry>
  675. <entry><code>array()</code></entry>
  676. <entry>
  677. Ein assoziatives Array, um Optionen nur für einige REQUEST_URI zu setzen. Die Schlüssel
  678. sind reguläre Ausdrücke (PCRE), die Werte sind ein assoziatives Array mit spezifischen
  679. Optionen, die gesetzt werden sollen, wenn der reguläre Ausdruck auf $_SERVER['REQUEST_URI']
  680. passt (siehe die default_options für eine Liste der verfügbaren Optionen); wenn verschiedene
  681. reguläre Ausdrücke auf $_SERVER['REQUEST_URI'] passen, wird nur der letzte verwendet.
  682. </entry>
  683. </row>
  684. <row>
  685. <entry><code>memorize_headers</code></entry>
  686. <entry><code>array</code></entry>
  687. <entry><code>array()</code></entry>
  688. <entry>
  689. Ein Array von Strings die zu einem HTTP Headernamen korrespondieren.
  690. Aufgelistete Header werden mit den Cache Daten gespeichert und wieder
  691. "abgespielt" wenn der Cache getroffen wird.
  692. </entry>
  693. </row>
  694. </tbody>
  695. </tgroup>
  696. </table>
  697. </sect3>
  698. <sect3 id="zend.cache.frontends.page.examples">
  699. <title>Beispiele</title>
  700. <para>
  701. Die Verwendung von <classname>Zend_Cache_Frontend_Page</classname> ist wirklich trivial :
  702. </para>
  703. <programlisting role="php"><![CDATA[
  704. // [...] // Benötigt, Konfiguration und Factory
  705. $cache->start();
  706. // Wenn der Cache gefunden wurde, wird das Ergebnis zum Browser geschickt,
  707. // und das Skript stoppt hier
  708. // Rest der Seite ...
  709. ]]>
  710. </programlisting>
  711. <para>
  712. Ein etwas komplexeres Beispiel, welches einen Weg zeigt, um ein zentralisiertes
  713. Cache Management in einer Bootstrap Datei zu erhalten (um es z.B. mit <classname>Zend_Controller</classname>
  714. zu verwenden)
  715. </para>
  716. <programlisting role="php"><![CDATA[
  717. /*
  718. * Es sollte vermieden werden, zu viele Zeilen vor dem Cache Bereich zu setzen
  719. * zum Beispiel sollten für optimale Performanz "require_once" oder
  720. * "Zend_Loader::loadClass" nach dem Cache Bereich stehen
  721. */
  722. $frontendOptions = array(
  723. 'lifetime' => 7200,
  724. 'debug_header' => true, // für das Debuggen
  725. 'regexps' => array(
  726. // cache den gesamten IndexController
  727. '^/$' => array('cache' => true),
  728. // cache den gesamten IndexController
  729. '^/index/' => array('cache' => true),
  730. // wir cachen nicht den ArticleController...
  731. '^/article/' => array('cache' => false),
  732. // ...aber wir cachen die "View" Aktion von diesem ArticleController
  733. '^/article/view/' => array(
  734. 'cache' => true,
  735. // und wir cachen sogar wenn es einige Variablen in $_POST gibt
  736. 'cache_with_post_variables' => true,
  737. // aber die Cache Id wird vom $_POST Array abhängig sein
  738. 'make_id_with_post_variables' => true,
  739. )
  740. )
  741. );
  742. $backendOptions = array(
  743. 'cache_dir' => '/tmp/'
  744. );
  745. // erhalte ein Zend_Cache_Frontend_Page Objekt
  746. $cache = Zend_Cache::factory('Page',
  747. 'File',
  748. $frontendOptions,
  749. $backendOptions);
  750. $cache->start();
  751. // Wenn der Cache gefunden wurde, wird das Ergebnis zum Browser geschickt,
  752. // und das Skript stoppt hier
  753. // [...] das Ende der Bootstrap Datei
  754. // diese Zeilen werden nicht ausgeführt, wenn der Cache ausgegeben wurde
  755. ]]>
  756. </programlisting>
  757. </sect3>
  758. <sect3 id="zend.cache.frontends.page.cancel">
  759. <title>Die spezielle cancel Methode</title>
  760. <para>
  761. Aus Designgründen, kann es in einigen Fällen (zum Beispiel bei Verwendung von nicht HTTP/200
  762. Return Codes), notwendig sein den aktuellen Cacheprozess zu unterbrechen. Deshalb zeigen wir
  763. für dieses spezielle Frontend die cancel() Methode.
  764. </para>
  765. <programlisting role="php"><![CDATA[
  766. // [...] // Benötigt, Konfiguration und Factory
  767. $cache->start();
  768. // [...]
  769. if ($someTest) {
  770. $cache->cancel();
  771. // [...]
  772. }
  773. // [...]
  774. ]]>
  775. </programlisting>
  776. </sect3>
  777. </sect2>
  778. </sect1>