Multiple Caches für eine Seite
Sie können für Aufrufe von display() oder fetch() auch mehrere Caches erzeugen.
Nehmen wir zum Beispiel an, der Aufruf von display('index.tpl')
erzeuge für verschieden Fälle unterschiedliche Inhalte und Sie
wollen jeden dieser Inhalte separat cachen. Um dies zu erreichen,
können Sie eine 'cache_id' beim Funktionsaufruf übergeben.
'display()' eine 'cache_id' übergeben
caching = true;
$my_cache_id = $_GET['article_id'];
$smarty->display('index.tpl',$my_cache_id);
?>
]]>
Im oberen Beispiel übergeben wir die Variable
$my_cache_id als 'cache_id' an display(). Für jede einmalige
cache_id wird ein eigener Cache von 'index.tpl'
erzeugt. In diesem Beispiel wurde 'article_id' per URL übergeben und
als 'cache_id' verwendet.
Technische Bemerkung
Seien Sie vorsichtig, wenn Sie Smarty (oder jeder anderen PHP-Applikation)
Werte direkt vom Client (Webbrowser) übergeben. Obwohl das Beispiel oben
praktisch aussehen mag, kann es schwerwiegende Konsequenzen haben. Die 'cache_id'
wird verwendet, um im Dateisystem ein Verzeichnis zu erstellen. Wenn ein Benutzer
also überlange Werte übergibt oder ein Skript benutzt, das in hohem
Tempo neue 'article_ids' übermittelt, kann dies auf dem Server zu Problemen
führen. Stellen Sie daher sicher, dass Sie alle empfangenen Werte auf
ihre Gültigkeit überprüfen und unerlaubte Sequenzen entfernen.
Sie wissen möglicherweise, dass ihre 'article_id' nur 10 Zeichen lang sein kann, nur
aus alphanumerischen Zeichen bestehen darf und in der Datenbank eingetragen
sein muss. Überpüfen sie das!
Denken Sie daran, Aufrufen von is_cached()
und clear_cache() als zweiten Parameter
die 'cache_id' zu übergeben.
'is_cached()' mit 'cache_id' aufrufen
caching = true;
$my_cache_id = $_GET['article_id'];
if(!$smarty->is_cached('index.tpl',$my_cache_id)) {
// kein Cache gefunden, also Variablen zuweisen
$contents = get_database_contents();
$smarty->assign($contents);
}
$smarty->display('index.tpl',$my_cache_id);
?>
]]>
Sie können mit clear_cache()
den gesamten Cache einer bestimmten 'cache_id' auf einmal löschen,
wenn Sie als Parameter die 'cache_id' übergeben.
Cache einer bestimmten 'cache_id' leeren
caching = true;
// Cache mit 'sports' als 'cache_id' löschen
$smarty->clear_cache(null,"sports");
$smarty->display('index.tpl',"sports");
?>
]]>
Indem Sie allen dieselbe 'cache_id' übergeben, lassen sich Caches gruppieren.