Manuel Smarty

Fonction de gestion du cache

Une alternative au mécanisme de cache par défaut (basé sur des fichiers de cache) consiste à spécifier une fonction de gestion de cache utilisateur qui sera utilisée pour lire, écrire et effacer les fichiers de cache.

Il suffit de créer dans votre application une fonction que Smarty utilisera pour la gestion du cache et d'assigner le nom de cette fonction à la variable de classe $cache_handler_func. Smarty utilisera alors cette fonction pour gérer les données du cache.

  • Le premier argument est l'action, qui sera read, write and clear.

  • Le second paramètre est l'objet Smarty.

  • Le troisième est le contenu du cache. Pour écrire, Smarty passe le contenu du cache dans ces paramètres. Pour lire, Smarty s'attend à ce que votre fonction accepte ce paramètre par référence et que vous le remplissiez avec les données du cache. Pour effacer, il suffit de passer une variable fictive car cette dernière n'est pas utilisée.

  • Le quatrième paramètre est le nom du fichier de template (utile pour lire/écrire).

  • Le cinquième paramètre est l'identifiant $cache_id.

  • Le sixième est l'identifiant optionnel $compile_id.

  • Le septième et dernier paramètre $exp_time a été ajouté dans Smarty-2.6.0.

Exemple 15-5. Exemple d'utilisation de MySQL pour la source du cache

  1. <?php
  2. /*****
  3.  
  4. exemple d'usage :
  5.  
  6. include('Smarty.class.php');
  7. include('mysql_cache_handler.php');
  8.  
  9. $smarty = new Smarty;
  10. $smarty->cache_handler_func = 'mysql_cache_handler';
  11.  
  12. $smarty->display('index.tpl');
  13.  
  14.  
  15. la base mysql est attendu dans ce format :
  16.  
  17. create database SMARTY_CACHE;
  18.  
  19. create table CACHE_PAGES(
  20. CacheID char(32) PRIMARY KEY,
  21. CacheContents MEDIUMTEXT NOT NULL
  22. );
  23.  
  24. *****/  
  25.  
  26. function mysql_cache_handler($action, &$smarty_obj, &$cache_content, $tpl_file=null, $cache_id=null, $compile_id=null)  
  27. {  
  28. // l'hôte de la bd, l'utilisateur, et le mot de passe
  29. $db_host = 'localhost';  
  30. $db_user = 'myuser';  
  31. $db_pass = 'mypass';  
  32. $db_name = 'SMARTY_CACHE';  
  33. $use_gzip = false;  
  34.  
  35. // crée un identifiant de cache unique
  36. $CacheID = md5($tpl_file.$cache_id.$compile_id);  
  37.  
  38. if(! $link = mysql_pconnect($db_host, $db_user, $db_pass)) {  
  39. $smarty_obj->_trigger_error_msg("cache_handler: could not connect to database"); 
  40.    return false;  
  41. }  
  42. mysql_select_db($db_name);  
  43.  
  44. switch ($action) { 
  45.    case 'read': 
  46.    // récupère le cache dans la base de données
  47.    $results = mysql_query("select CacheContents from CACHE_PAGES where CacheID='$CacheID'"); 
  48.    if(!$results) { 
  49.       $smarty_obj->_trigger_error_msg('cache_handler: query failed.'); 
  50.    } 
  51.    $row = mysql_fetch_array($results,MYSQL_ASSOC); 
  52.  
  53.    if($use_gzip && function_exists('gzuncompress')) { 
  54.       $cache_content = gzuncompress($row['CacheContents']); 
  55.    } else { 
  56.       $cache_content = $row['CacheContents']; 
  57.    } 
  58.    $return = $results; 
  59.    break; 
  60.    case 'write': 
  61.    // sauvegarde le cache dans la base de données
  62.  
  63.    if($use_gzip && function_exists("gzcompress")) { 
  64.       // compresse le contenu pour gagner de la place
  65.       $contents = gzcompress($cache_content); 
  66.    } else { 
  67.       $contents = $cache_content; 
  68.    } 
  69.    $results = mysql_query("replace into CACHE_PAGES values(
  70.                                   '$CacheID',
  71.                                   '".addslashes($contents)."')
  72.                                   "); 
  73.    if(!$results) { 
  74.       $smarty_obj->_trigger_error_msg('cache_handler: query failed.'); 
  75.    } 
  76.    $return = $results; 
  77.    break; 
  78.    case 'clear': 
  79.    // efface les données du cache
  80.    if(empty($cache_id) && empty($compile_id) && empty($tpl_file)) { 
  81.       // les efface toutes
  82.       $results = mysql_query('delete from CACHE_PAGES'); 
  83.    } else { 
  84.       $results = mysql_query("delete from CACHE_PAGES where CacheID='$CacheID'"); 
  85.    } 
  86.    if(!$results) { 
  87.       $smarty_obj->_trigger_error_msg('cache_handler: query failed.'); 
  88.    } 
  89.    $return = $results; 
  90.    break; 
  91.    default: 
  92.    // erreur, action inconnue
  93.    $smarty_obj->_trigger_error_msg("cache_handler: unknown action \"$action\""); 
  94.    $return = false; 
  95.    break;  
  96. }  
  97. mysql_close($link);  
  98. return $return;  
  99.  
  100. }  
  101.  
  102. ?> 

Remonter Remonter
L'éditeur javascript - CSS - Gentoo - Tutoriaux PHP - Tutoriels PHP - Bretagne - php - Moto - Kit graphique