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

Funzione di gestione della Cache

Come alternativa all'uso del meccanismo di default per la cache basato sui file, potete specificare una funzione personalizzata di gestione che verrà usata per leggere, scrivere ed eliminare i file in cache.

Create una funzione nella vostra applicazione che Smarty userà come gestore della cache. Impostate il nome di questa funzione nella variabile di classe $cache_handler_func. Smarty ora userà questa funzione per gestire i dati della cache. Il primo parametro è l'azione, che può essere 'read', 'write' o 'clear'. Il secondo parametro è l'oggetto Smarty. Il terzo parametro è il contenuto in cache. In una 'write', Smarty passa il contenuto da mettere in cache in questo parametro. In una 'read', Smarty si aspetta che la funzione prenda questo parametro per riferimento e che lo riempia con i dati della cache. In una 'clear', il parametro non viene usato, quindi passate una variabile dummy. Il quarto parametro è il nome del file del template (necessario per le read e le write), il quinto parametro è il cache_id (opzionale), e il sesto è il compile_id (opzionale).

Nota: l'ultimo parametro ($exp_time) è stato aggiunto in Smarty-2.6.0.

Example 15.5. esempio con l'uso di MySQL per la cache


<?php
/*

esempio:

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

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

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


il database mysql avrà questo formato:
	
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, $exp_time=null)
{
	// impostiamo i dati d'accesso al db
	$db_host = 'localhost';
	$db_user = 'myuser';
	$db_pass = 'mypass';
	$db_name = 'SMARTY_CACHE';
	$use_gzip = false;
	
	// creiamo un cache id unico
	$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':
			// leggiamo la cache dal database
			$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':
			// salviamo la cache sul database
			
			if($use_gzip && function_exists("gzcompress")) {
				// compress the contents for storage efficiency
				$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':
			// eliminiamo i dati in cache
			if(empty($cache_id) && empty($compile_id) && empty($tpl_file)) {
				// eliminiamo tutto
				$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:
			// errore, azione non prevista
			$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