本文實(shí)例講述了Smarty模板引擎緩存機(jī)制。分享給大家供大家參考,具體如下:
首先說(shuō)下smarty緩存和編譯,這是兩個(gè)不同的概念,編譯默認(rèn)情況下是啟動(dòng)的,而緩存機(jī)制需要人為開啟,smarty編譯過(guò)的文件還是php文件,所以執(zhí)行的時(shí)候還是編譯的,如果涉及到數(shù)據(jù)庫(kù),還是要訪問(wèn)數(shù)據(jù)庫(kù)的所以開銷也不小啦,所以需要smarty緩存來(lái)解決!
1.開啟全局緩存
$smarty->cache_dir = "/caches/"; //緩存目錄
$smarty->caching = true; //開啟緩存,為flase的時(shí)侯緩存無(wú)效
$smarty->cache_lifetime = 3600; //緩存時(shí)間
2.一個(gè)頁(yè)面使用多個(gè)緩存
如:一個(gè)文章模板頁(yè)面會(huì)生成多個(gè)文章頁(yè)面,當(dāng)然是緩存成很多頁(yè)面,實(shí)現(xiàn)起來(lái)很簡(jiǎn)單,只要在display()方法設(shè)置第二個(gè)參數(shù),指定唯一標(biāo)識(shí)符即可。如下php代碼:
$smarty->display('index.tpl',$_GET["article_id"]);
如上,通過(guò)第二個(gè)參數(shù)文章的id緩存一個(gè)文章頁(yè)面。
3.為緩存減小開銷
也就是說(shuō),已經(jīng)緩存的頁(yè)面無(wú)需進(jìn)行數(shù)據(jù)庫(kù)的操作處理了,可通過(guò)is_cached()方法判斷!
if(!$smarty->is_cached('index.tpl')){
//調(diào)用數(shù)據(jù)庫(kù)
}
$smarty->display('index.tpl');
4.清除緩存
一般在開發(fā)過(guò)程中是不開啟緩存的,因?yàn)樵诰彺鏁r(shí)間內(nèi)輸出結(jié)果不變,但是在應(yīng)用過(guò)程中開啟緩存能大大提高web性能,清除緩存方法如下:
clear_all_cache();//清除所有緩存
clear_cache('index.tpl');//清除index.tpl的緩存
clear_cache('index.tpl',cache_id);//清除指定id的緩存
5.關(guān)閉局部緩存
如果一個(gè)頁(yè)面中一部分緩存,而另一部分不需要緩存,就可以這樣做,比如說(shuō)顯示用戶登錄的名稱就需要關(guān)閉緩存,smarty提供了如下三種解決方法:
(1)使用insert模板的一部分不被緩存
定義一個(gè)inser標(biāo)簽要使用的處理函數(shù),函數(shù)名格式為:insert_xx(array $params, object &$smarty)其中的xx是insert的name,也就是說(shuō),如果你定義的函數(shù)為insert_abc,則模板中使用方法為{insert name=abc}
參數(shù)通過(guò)$params傳入
也可以做成insert插件,文件名命名為:insert.xx.php,函數(shù)命名為:smarty_insert_aa($params,&$smarty),xx定義同上
(2)$smarty->register_block($params, &$smarty)使整篇頁(yè)面中的某一塊不被緩存
定義一個(gè)block:
smarty_block_name($params,$content, &$smarty){return $content;}
//name表示區(qū)域名
注冊(cè)block:
$smarty->register_block(name, smarty_block_name, false);
//第三參數(shù)false表示該區(qū)域不被緩存
模板寫法:
{name}內(nèi)容 {/name}
寫成block插件:
第一步:定義一件插件函數(shù):block.cacheless.php,放在smarty的 plugins目錄
block.cacheless.php的內(nèi)容如下:
<?php
function smarty_block_cacheless($param, $content, &$smarty) {
return $content;
}
?>
第二步:編寫程序及模板
示例程序:testCacheLess.php
<?php
include(Smarty.class.php);
$smarty = new Smarty;
$smarty->caching=true;
$smarty->cache_lifetime = 6;
$smarty->display(cache.tpl);
?>
所用的模板:cache.tpl
已經(jīng)緩存的:{$smarty.now}<br>
{cacheless}
沒(méi)有緩存的:{$smarty.now}
{/cacheless}
現(xiàn)在運(yùn)行一下,發(fā)現(xiàn)是不起作用的,兩行內(nèi)容都被緩存了
第三步:改寫Smarty_Compiler.class.php(注:該文件很重要,請(qǐng)先備份,以在必要時(shí)恢復(fù))
查找:
復(fù)制代碼 代碼如下:
$this->_plugins[block][$tag_command] = array($plugin_func, null, null, null, true);
修改成:
if($tag_command == cacheless) $this->_plugins[block][$tag_command] = array($plugin_func, null, null, null, false);
else $this->_plugins[block][$tag_command] = array($plugin_func, null, null, null, true);
你也可以直接將原句的最后一個(gè)參數(shù)改成false,即關(guān)閉默認(rèn)緩存。
(3)使用register_function阻止插件從緩存中輸出
index.tpl:
<div>{current_time}{/div}
index.php:
function smarty_function_current_time($params, &$smarty){
return date("Y-m-d H:m:s");
}
$smarty=new smarty();
$smarty->caching = true;
$smarty->register_function('current_time','smarty_function_current_time',false);
if(!$smarty->is_cached()){
.......
}
$smarty->display('index.tpl');
注解:
定義一個(gè)函數(shù),函數(shù)名格式為:smarty_type_name($params, &$smarty)
type為function
name為用戶自定義標(biāo)簽名稱,在這里是{current_time}
兩個(gè)參數(shù)是必須的,即使在函數(shù)中沒(méi)有使用也要寫上。兩個(gè)參數(shù)的功能同上。
希望本文所述對(duì)大家基于smarty模板的PHP程序設(shè)計(jì)有所幫助。