What is Smarty?
Why use it?
Use Cases and Work Flow
Syntax Comparison
Template Inheritance
Best Practices
Crash Course
You may use the Smarty logo according to the trademark notice.
For sponsorship, advertising, news or other inquiries, contact us at:
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.
Example 14.6. 'display()' eine 'cache_id' übergeben
<?php require('Smarty.class.php'); $smarty = new Smarty; $smarty->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.
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.
Example 14.7. 'is_cached()' mit 'cache_id' aufrufen
<?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)) { // 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.
Example 14.8. Cache einer bestimmten 'cache_id' leeren
<?php require('Smarty.class.php'); $smarty = new Smarty; $smarty->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.