Get Smarty


Donate Bitcoin Bitcoin

Smarty Icon

You may use the Smarty logo according to the trademark notice.

Smarty Template Engine Smarty Template Engine

For sponsorship, advertising, news or other inquiries, contact us at:

Sites Using Smarty

Buy cheap glasses from and save up to 80%.

Where to buy dental loupes? is your best choice!

Where to buy discount wedding dresses and cheap smart dresses free shipping -

Find Wedding Dresses Online at Canada from

Wholesale Fashion Jewelry from wholesalers

soccer kp is New 2016 Nike Mercurial Superfly V soccer cleats from


Cache Handler Funktion

Als Alternative zum normalen dateibasierten Caching-Mechanismus können Sie eine eigene Cache-Handler Funktion zum lesen, schreiben und löschen von Cache-Dateien definieren.

Schreiben Sie eine Funktion in Ihrer Applikation, die Smarty als Cache-Handler verwenden soll und weisen Sie deren Name der Variable $cache_handler_func zu. Smarty wird von da an Ihre Funktion zur Bearbeitung des Caches verwenden. Als erster Parameter wird die 'action' mit einem der folgendende Werte übergeben: 'read', 'write' und 'clear'. Als zweiter Parameter wird das Smarty-Objekt übergeben, als dritter der gecachte Inhalt. Bei einem 'write' übergibt Smarty den gecachten Inhalt, bei 'read' übergibt Smarty die Variable als Referenz und erwartet, dass Ihre Funktion die Inhalte zuweist. Bei 'clear' können Sie eine dummy-Variable übergeben. Als vierter Parameter wird der Template-Name übergeben (verwendet bei 'write'/'read'), als fünfter Parameter die 'cache_id' (optional) und als sechster die 'compile_id' (auch optional).

Der letzte Parameter ($exp_time) wurde in Smarty-2.6.0 hinzugefügt.

Example 15.5. Beispiel mit einer MySQL Datenbank als Datenquelle


Beispiel Anwendung:


$smarty = new Smarty;
$smarty->cache_handler_func = 'mysql_cache_handler';


die Datenbank hat folgendes Format:

create database SMARTY_CACHE;

create table CACHE_PAGES(
CacheID char(32) PRIMARY KEY,


function mysql_cache_handler($action, &amp;$smarty_obj, &amp;$cache_content, $tpl_file=null, $cache_id=null, $compile_id=null)

    // Datenbank Host, Benutzer und Passwort festlegen
   $db_host = 'localhost';
   $db_user = 'myuser';
   $db_pass = 'mypass';
   $db_name = 'SMARTY_CACHE';
   $use_gzip = false;

   // enmalige 'cache_id' erzeugen
   $CacheID = md5($tpl_file.$cache_id.$compile_id);

   if(! $link = mysql_pconnect($db_host, $db_user, $db_pass)) {
      $smarty_obj->_trigger_error_msg("cache_handler: could not connect to database");
      return false;

   switch ($action) {
   case 'read':

      // Cache aus der Datenbank lesen
      $results = mysql_query("select CacheContents from CACHE_PAGES where CacheID='$CacheID'");
      if(!$results) {
	 $smarty_obj->_trigger_error_msg("cache_handler: query failed.");
      $row = mysql_fetch_array($results,MYSQL_ASSOC);
      if($use_gzip &amp;&amp; function_exists("gzuncompress")) {
	 $cache_contents = gzuncompress($row["CacheContents"]);
      } else {
	 $cache_contents = $row["CacheContents"];
      $return = $results;

   case 'write':

      // Cache in Datenbank speichern
      if($use_gzip &amp;&amp; function_exists("gzcompress")) {
	 // compress the contents for storage efficiency
	 $contents = gzcompress($cache_content);
      } else {
	 $contents = $cache_content;
      $results = mysql_query("replace into CACHE_PAGES values(
      if(!$results) {
	 $smarty_obj->_trigger_error_msg("cache_handler: query failed.");
      $return = $results;
   case 'clear':
      // Cache Informationen löschen
      if(empty($cache_id) &amp;&amp; empty($compile_id) &amp;&amp; empty($tpl_file)) {
	 // alle löschen
	 $results = mysql_query("delete from CACHE_PAGES");
      } else {
	 $results = mysql_query("delete from CACHE_PAGES where CacheID='$CacheID'");
      if(!$results) {
	 $smarty_obj->_trigger_error_msg("cache_handler: query failed.");
      $return = $results;
      // Fehler, unbekannte 'action'
      $smarty_obj->_trigger_error_msg("cache_handler: unknown action \"$action\"");
      $return = false;
   return $return;



No comments for this page.
Post a Comment
All comments are moderated. Support questions are ignored, use the forums instead.
Email: (not shown)
What is 2 plus 16? (Are you human?)