smarty template engine
Monday, October 13, 2008  
download | documentation | faq | forum | mailing lists | changelog | contribs 


search for in the  


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.

Beispiel 15-5. Beispiel mit einer MySQL Datenbank als Datenquelle

<?php
/*

Beispiel Anwendung:

include('Smarty.class.php');
include('mysql_cache_handler.php');

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

$smarty->display('index.tpl');


die Datenbank hat folgendes Format:

create database SMARTY_CACHE;

create table CACHE_PAGES(
CacheID char(32) PRIMARY KEY,
CacheContents MEDIUMTEXT NOT NULL
);

*/

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;
   }
   
mysql_select_db($db_name);

   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;&ampfunction_exists("gzuncompress")) {
     
$cache_contents gzuncompress($row["CacheContents"]);
      } else {
     
$cache_contents $row["CacheContents"];
      }
      
$return $results;
      break;

   case 
'write':

      
// Cache in Datenbank speichern
      
if($use_gzip &amp;&ampfunction_exists("gzcompress")) {
     
// compress the contents for storage efficiency
     
$contents gzcompress($cache_content);
      } else {
     
$contents $cache_content;
      }
      
$results mysql_query("replace into CACHE_PAGES values(
   '$CacheID',
   '"
.addslashes($contents)."')
   "
);
      if(!
$results) {
     
$smarty_obj->_trigger_error_msg("cache_handler: query failed.");
      }
      
$return $results;
      break;
   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;
      break;
   default:
      
      
// Fehler, unbekannte 'action'
      
$smarty_obj->_trigger_error_msg("cache_handler: unknown action \"$action\"");
      
$return false;
      break;
   }
   
mysql_close($link);
   return 
$return;
   
}

?>



 

credits 

Smarty Copyright © 2002-2008
New Digital Group, Inc.

All rights reserved.