Overview
KB
Learn PHP
PHP techniques
PHP Smarty Functions
PHP Web Email
Secure development
PHP Security Scenario
SSH and SFTP
PHP Smarty
PHP Smarty Modifiers
PHP Smarty Caching
PHP Smarty Misc
CakePHP
Zend Framework
PHP basics

PHP Smarty Caching

Caching is a way of improving a Web page's performance by saving the executed version of a page as a static file. This allows the server to handle multiple requests for the same page with only one execution of the underlying PHP script. Caching can be applied to any type of content provided to the browser by the server but it makes particular sense to use it with templated pages. Smarty caching refers to a built-in caching that's easy to use.

Enabling Caching in Smarty

To turn on caching for a page, set the "caching" attribute to 1:
require('Smarty.class.php'); 
$page = new Smarty(); 
$page->caching = 1; 
$page->display('demotpl.tpl');
The first time this code is run, the resulting HTML page will be sent to the Web browser and saved as a file in Smarty's cache directory. Subsequent executions of this page will result in the cached version being sent to the Web browser.

Adjusting the Cache Expiration or Lifetime

Every cached page has an associated timestamp, indicating for how long the cached page is good. By default this is one hour from the time the file was created. This is important to pay attention to because given the above code, the cached version of the page will be provided to the requesting user, no matter what changes might have been made to the template or the data used in the template in the interim. For example, if you were to use caching like this on a message board, users would effectively only see updates every hour, as in-between requests would receive the saved version of the page. To adjust the smarty cache lifetime of a page, set the "caching" attribute to 2 and set the "cache_lifetime" attribute to some number in seconds:
require('Smarty.class.php'); 
$page = new Smarty(); 
$page->caching = 2; 
$page->cache_lifetime = 1800; // 30 minutes 
$page->display('template.tpl');

Checking the Cache

the cache code
Smarty only takes advantage of a cached version of a page once it gets to the display() (or fetch()) method call. But if a PHP page has some amount of activity, like retrieving from a database or file the information to be used on the page, that PHP code will still be executed. This makes the cache less efficient than it could be. To improve upon this system, check for a valid cached version of the page prior to doing any potentially unnecessary execution:
require('Smarty.class.php'); 
$page = new Smarty(); 
$page->caching = 1; 
if (!$page->is_cached('template.tpl')) { // If the page isn't cached... 
    // Do whatever is necessary. 
    $page->assign('placeholder', 'value'); 
    // Etc. 
} 
$page->display('template.tpl');

Article continues:  next page>>

 Download NuSphere PHP IDE

Download a free trial of the fast PHP EDitor and robust Integrated Development Environment for PHP.

 Buy NuSphere PhpED® now

Best PHP Editor and complete PHP IDE.
NuSphere PhpED 21.0 is available from our online store front.

 Special Team4 Offer

Get 4 copies of PhpED for the price of 3!

Optimum solution for development teams.
PhpED 21.0 Team4
Need more than 4 licenses? Contact Us for more quantity discounts, please use "Ordering/Payment issue" subject on the form.
"To be honest its bloody awesome, I have looked at loads of PHP editors and this is THE only one that actual works straight out of the box!!! Brilliant, well done."
Andrew Breward,
Director of Technology
caboodal.com