Get Smarty

Donate

Paypal

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

Advertisement

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.

Example 15.5. Exemple d'utilisation de MySQL pour la source du cache


<?php
/*****

exemple d'usage :

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

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

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


la base mysql est attendu dans ce format :

create database SMARTY_CACHE;

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

*****/

function mysql_cache_handler($action, &$smarty_obj, &$cache_content, $tpl_file=null, $cache_id=null, $compile_id=null)
{
  // l'hôte de la bd, l'utilisateur, et le mot de passe
  $db_host = 'localhost';
  $db_user = 'myuser';
  $db_pass = 'mypass';
  $db_name = 'SMARTY_CACHE';
  $use_gzip = false;

  // crée un identifiant de cache unique
  $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':
      // récupère le cache dans la base de données
      $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 && function_exists('gzuncompress')) {
        $cache_content = gzuncompress($row['CacheContents']);
      } else {
        $cache_content = $row['CacheContents'];
      }
      $return = $results;
      break;
    case 'write':
      // sauvegarde le cache dans la base de données

      if($use_gzip && function_exists("gzcompress")) {
        // compresse le contenu pour gagner de la place
        $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':
      // efface les données du cache
      if(empty($cache_id) && empty($compile_id) && empty($tpl_file)) {
        // les efface toutes
        $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:
      // erreur, action inconnue
      $smarty_obj->_trigger_error_msg("cache_handler: unknown action \"$action\"");
      $return = false;
      break;
  }
  mysql_close($link);
  return $return;

}

?>

  

Comments
No comments for this page.

Advertisement

Sponsors [info]

Sponsors