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.