Multiples caches por pagina

Usted puede tener multiples archivos de cache para una simples llamada de display() o fetch(). Vamos a decir que una llamada a display('index.tpl') debe tener varios contenidos de salida diferentes dependiendo de alguna condición, y usted quiere separar los caches para cada una. Usted puede hacer esto pasando un cache_id como un segundo parámetro en la llamada de la función.

Ejemplo 14-6. Pasando un cache_id para display()

<?php
require('Smarty.class.php');
$smarty = new Smarty;

$smarty->caching true;

$my_cache_id $_GET['article_id'];

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

Arriba, nosotros pasamos la variable $my_cache_id a display() con el cache_id. Para cada valor unico de $my_cache_id, un cache por separado sera generado para cada index.tpl. En este ejemplo, "article_id" fue pasado en URL y es usado como el cache_id.

Nota Técnica: Tenga mucho cuidado cuando pase valores del cliente (web browser) dentro de Smarty (o alguna aplicación PHP). Aunque el ejemplo de arriba usar el article_id desde una URL parece facil, esto podría tener fatales consecuencias. El cache_id es usado para crear un directorio en el sistema de archivos, entonces si el usuario decide pasar un valor extremadamente largo para article_id, o escribir un script que envia article_ids aleatorios en un paso rápido, esto posiblemente podría causar problemas a nivel del servidor. Tenga la certeza de limpiar algún dato pasado antes de usarlo. En este ejemplo, tal vez usted sabia que el article_id tiene un largo de 10 caracteres este es constituido solamente de alfanuméricos, y debe ser un article_id valido en la base de datos. Verifique esto!

Asegurarse de pasar el mismo cache_id como el segundo parámetro para is_cached() y clear_cache().

Ejemplo 14-7. Pasando un cache_id para is_cached()

<?php
require('Smarty.class.php');
$smarty = new Smarty;

$smarty->caching true;

$my_cache_id $_GET['article_id'];

if(!
$smarty->is_cached('index.tpl',$my_cache_id)) {
    
// No cache available, do variable assignments here.
    
$contents get_database_contents();
    
$smarty->assign($contents);
}

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

Usted puede limpar todos los caches para un cache_id en particular pasando el primer parámetro null a clear_cache()..

Ejemplo 14-8. Limpando todos los caches para un cache_id en particular

<?php
require('Smarty.class.php');
$smarty = new Smarty;

$smarty->caching true;

// clear all caches with "sports" as the cache_id
$smarty->clear_cache(null,"sports");

$smarty->display('index.tpl',"sports");
?>

De esta manera, usted puede "agrupar" sus caches conjuntamente dando les el mismo cache_id.