| // | Christian Stocker | // | Vinai Kopp | // +----------------------------------------------------------------------+ // // $Id: Output.php 178289 2005-01-26 09:47:28Z dufuz $ require_once 'Cache.php'; /** * Class to cache the output of a script using the output buffering functions * * Simple output cache. Some pages require lots of time to compute. Caching the * output can increase the overall speed dramatically, especially if you use * a Shared Memory storage container. * * As you can see in the example the usage is extemely simple. To cache a script * simple put some few lines of code in front of your script and some at the end. * A preferrable place for this are the auto_prepend and auto_append files (=> php.ini). * * Usage example: * * // place this somewhere in a central config file * define(CACHE_STORAGE_CLASS, 'file'); * // file storage needs a dir to put the cache files * define(CACHE_DIR, '/var/tmp/'); * * // get a cache object * $cache = new Cache_Output(CACHE_STORAGE_CLASS, array('cache_dir' => CACHE_DIR)); * * // compute the unique handle. * // if your script depends on Cookie and HTTP Post data as well * // you should use: * // $cache_handle = array( * // 'file' => $REQUEST_URI, * // 'post' => $HTTP_POST_VARS, * // 'cookie' => $HTTP_COOKIE_VARS * // ); * // But be warned, using all GET or POST Variables as a seed * // can be used for a DOS attack. Calling http://www.example.com/example.php?whatever * // where whatever is a random text might be used to flood your cache. * $cache_handle = $cache->generateID($REQUEST_URI); * * // now the magic happens: if cached call die() * // to end the time consumptiong script script execution and use the cached value! * if ($content = $cache->start($cache_handle)) { * print $content; * print '

Cache hit

'; * die(); * } * * // time consumption script goes here. * * // store the output of the cache into the cache and print the output. * print $cache->end(); * print "

Cache miss, stored using the ID '$id'.

"; * * If you do not want to cache a whole page - no problem: * * if (!($content = $cache->start($cache_handle))) { * // do the computation here * print $cache->end() * } else { * print $content; * } * * If you need an example script check the (auto_)prepend and (auto_)append * files of my homepage: * * http://www.ulf-wendel.de/php/show_source.php?file=prepend * http://www.ulf-wendel.de/php/show_source.php?file=append * * Don't know how to use it or you need profiling informations?` * Ask Christian he was patient with me and he'll be so with your questions ;). * * Have fun! * * @authors Ulf Wendel * @version $ID: $ * @package Cache * @access public */ class Cache_Output extends Cache { /** * ID passed to start() * * @var string * @see start(), end() */ var $output_id = ''; /** * Group passed to start() * * @var string * @see start(), end() */ var $output_group = ''; /** * PEAR-Deconstructor * Call deconstructor of parent */ function _Cache_Output() { $this->_Cache(); } /** * starts the output buffering and returns an empty string or returns the cached output from the cache. * * @param string dataset ID * @param string cache group * @return string * @access public */ function start($id, $group = 'default') { if (!$this->caching) { return ''; } // this is already cached return it from the cache so that the user // can use the cache content and stop script execution if ($content = $this->get($id, $group)) { return $content; } // remember some data to be able to fill the cache on calling end() $this->output_id = $id; $this->output_group = $group; // WARNING: we need the output buffer - possible clashes ob_start(); ob_implicit_flush(false); return ''; } // end func start /* * Stores the content of the output buffer into the cache and returns the content. * * @param mixed lifetime of the cached data in seconds - 0 for endless. More formats available. see Container::getExpiresAbsolute() * @param string additional userdefined data * @return string cached output * @access public * @see endPrint(), endGet(), Container::getExpiresAbsolute() */ function end($expire = 0, $userdata = '') { $content = ob_get_contents(); ob_end_clean(); // store in the cache if ($this->caching) { $this->container->save($this->output_id, $content, $expire, $this->output_group, $userdata); } return $content; } // end func end() /** * Stores the content of the output buffer into the cache and prints the content. * * @brother end() */ function endPrint($expire = 0, $userdata = '') { $this->printContent($this->end($expire, $userdata)); } // end func endPrint /** * Sends the data to the user. * This is for compatibility with OutputCompression * * @param string * @access public */ function printContent($content = '') { if ($content == '') { $content = &$this->container->cachedata; } print $content; } /** * Returns the content of the output buffer but does not store it into the cache. * * Use this method if the content of your script is markup (XML) * that has to be parsed/converted (XSLT) before you can output * and store it into the cache using save(). * * @return string * @access public * @see endPrint(), end() */ function endGet() { $content = ob_get_contents(); ob_end_clean(); $this->output_id = ''; $this->output_group = ''; return $content; } // end func endGet } // end class output ?>