Zend Framework中有3种常用的前端类,分别是
Zend_Cache_Core
Zend_Cache_Frontend_Output
Zend_Cache_Frontend_Page
与之对应的ASP.NET中的概念分别是数据缓存,片段缓存,页面缓存。
其中Zend_Cache_Frontend_Output和Zend_Cache_Frontend_Page都继承了Zend_Cache_Core。
在创建缓存的时候,对应的代码如下,这些代码一般写在资源方法中,Bootstrap.php文件内。
if (false == Zend_Registry::isRegistered('coreCache')) { $frontendOptions = array( 'lifetime' => 10, 'automatic_serialization' => true ); $backendOptions = array( 'cache_dir' => APPLICATION_PATH . '/tmp' ); $core_cache = Zend_Cache::factory('Core', 'File', $frontendOptions, $backendOptions); Zend_Registry::set('coreCache', $core_cache); }
if (false == Zend_Registry::isRegistered('outputCache')) { $frontendOptions = array( 'lifetime' => 10 ); $backendOptions = array( 'cache_dir' => APPLICATION_PATH . '/tmp' ); $output_cache = Zend_Cache::factory('Output', 'File', $frontendOptions, $backendOptions); Zend_Registry::set('outputCache', $output_cache); }
if (false == Zend_Registry::isRegistered('pageCache')) { $frontendOptions = array( 'lifetime' => 4 ) ; $backendOptions = array( 'cache_dir' => APPLICATION_PATH . '/tmp' ); $page_cache = Zend_Cache::factory('Page', 'File', $frontendOptions, $backendOptions); Zend_Registry::set('pageCache', $page_cache); }
Zend_Cache_Core主要用来缓存数据。比如数组,字符串之类的。类似ASP.NET中的数据缓存。下面的代码演示如何用缓存。
try { $core_cache = Zend_Registry::get('coreCache'); $z_now = Zend_Date::now(); if (!$result = $core_cache->load("now")) // 缓存未命中 { echo "缓存未命中<br>"; $core_cache->save($z_now, "now");//加入缓存 echo $z_now; } else { echo "缓存命中<br>"; echo $result; } } catch (Exception $e) { echo $e->getMessage(); }
初次打开页面,由于没有缓存,因此缓存未命中,把当前时间加入缓存中。然后刷新页面,缓存已经有了,直接读缓存,因此会发现时间不变。
当10秒后缓存失效,缓存又未命中了。
Zend_Cache_Frontend_Output继承了Zend_Cache_Core,因此上述的缓存数据的方法,它也可以使用。
同时它是一个输出捕捉前端.它在PHP中使用输出缓冲捕获start() 和 end() 方法间的一切输出. 类似于ASP.NET中的片段缓存。看如下示例代码:
try { $output_cache = Zend_Registry::get('outputCache'); if (!($output_cache->start('myoutput'))) { echo Zend_Date::now(); $output_cache->end(); // output buffering ends echo "缓存未命中"; } echo "<br>当前时间为:"; echo Zend_Date::now(); } catch (Exception $e) { echo $e->getMessage(); }
$output_cache->start('myoutput') 这句话,如果已经有了myoutput这个缓存的话,也就是说start方法返回的是true的话,则if里面的语句运行了。直接把myoutput这个缓存的内容输出一遍。否则,重新记录一遍myoutput缓存,缓存的内容就是送start到end之间的内容。发送缓存记录后,后续的代码继续运行下去。
Zend_Cache_Frontend_Page同样继承了Zend_Cache_Core,它和Zend_Cache_Frontend_Output类似,但不同的是,它不是缓存单一的数据片断,而是缓存整个页面。因此它只有start方法,没有end方法,或者说当程序运行完,会自动的运行end方法。使用更简单,只需要代码如下:
try { $page_cache = Zend_Registry::get('pageCache'); $page_cache->start(); echo Zend_Date::now(); } catch (Exception $e) { echo $e->getMessage(); }
首次的时候,会把start方法后面的输出都会缓存起来。下次运行的时候,缓存命中的话,就直接发送缓存,而不执行下面的语句了。如果后续的语句是数据库中的数据,则会节省了数据库读取操作。提升了效率。