PHP模板引擎Smarty的缓存使用总结
作者:
这里我们将分析一下如何开启和使用smarty缓存,如何清除smarty缓存以及smarty的全局缓存,部分缓存,局部缓存三种缓存机制。
一、开启和使用smarty缓存
要开启smarty的缓存,只需在smarty设置参数里面将caching设为true,并指定cache_dir即可。同时设置cache_lefetime参数指定缓存生存时间(单位为秒)。如果要对相同页面生成多个不同的缓存,可以在display或fetch中加入第二参数cache_id,如:
此特性可用于对不同的$_GET进行不同的缓存。
二、清除smarty缓存
清除smarty缓存一般有以下几种方式:
clear_all_cache();//清除所有缓存
clear_cache('index.tpl');//清除指定模板index.tpl的缓存
clear_cache('index.tpl',cache_id);//清除指定模板指定id的缓存
三、全局缓存
全局缓存就是为整个网站的全部页面都生成缓存页面。设置全局缓存首先我们要操作smarty的配置文件,开启缓存,指定缓存文件目录,并设置缓存的存活时间,设置参数如下:
$smarty->cache_dir='./cache/'; //设置存放缓存文件的文件夹
$smarty->caching=1;//开启缓存 0、FALSE代表关闭|非0数字、TRUE代表开启
$smarty->cache_lifetime=3600//单位为秒(如果填写-1为永不过期)
接下来我们要去具体的php页面设置与之对应的具体缓存文件的名字,在php页面中可按如下写法:
需要注意的是:
$smarty->display('与之对应的模板文件名','缓存文件名的补充部分')这个方法。
第二个参数不是必须的,如果不写的话,缓存文件名就是模板文件名经过加密处理后的文件。但是这样会碰到一个比较棘手的问题,例如:
https://www.jb51.net/article.php?id=5
https://www.jb51.net/article.php?id=7
这两个个URL对应应该的不同的内容,但是生成的缓存文件名都是 article 加密后的结果。这就会导致用户想要查询的是不同的内容,访问的却是同一个缓存文件。所以建议加上一个辅助参数,将访问url(包含?后面的所有参数)md5加密是比较靠谱的一种做法。
四、部分缓存
部分缓存就是指定一些文件生成缓存文件,而非网站的全部文件。部分缓存的实质其实是部分不缓存,也就是说不是指定哪些文件生成缓存,而是指定具体一些文件不生成缓存。现在假设有3个文件:
https://www.jb51.net/index.php //需要缓存
https://www.jb51.net/cate.php //需要缓存
https://www.jb51.net/article.php //不需要缓存
前面两个文件的php文件里面还是需要写上$smarty->display('与之对应的模板文件名','缓存文件名的补充部分')这句。
但在第三个文件中我们要特别指明不需要生成缓存,具体的方法是在display指定模板之前写上下面这段代码:
$smarty->clear_cache('与之对应的模板文件名');//其实写在$smarty->display('与之对应的模板文件名')之前还是之后都可以
当然$smarty->display('与之对应的模板文件名')还是要写,本来就不想生成缓存,第二个参数也就不需要了。
注意:$smarty->clear_cache()和$smarty->display()的参数一定要写成一致的
五、局部缓存
局部缓存就是指定同一页面下的某些局部地方生成缓存。其实它不是指定哪些局部生成缓存,而是哪些局部不生成缓存(这和部分缓存的操作思想是类似的)。我们先来看下面一个例子:
article.php 文件部分内容如下:
<?php
$time=time();
$smarty->assign('time',$lanmuarr);
function insert_timeget(){
return time();
}
$smarty->display('article.html');
对应模板文件article.html部分代码如下:
<body>
{$time}<!--开启缓存后,重复刷新这个值不会变-->
{insert name='timeget'}<!--开启缓存后,重复刷新这个值会变-->
</body>
这里对上面的例子做一下解释:在PHP中我们只要定义了函数名为 insert_ (注意下划线)自定义补充名的自定义函数,在其中返回的值,不需要assign()方法传递,就能直接在模板页面中以{insert name='自定义补充名'}的方式调用,同时不会受到缓存的影响,而实时刷新。
另外补充的一下是如果你感觉使用 Smarty 缓存不够爽的话,还可以使用自定义缓存,如何使用自定义缓存呢?
这里需要设置cache_handler_func使用自定义的函数处理缓存,如:
$smarty->cache_handler_func="myCache";
function myCache($action,&$smarty_obj,&$cache_content,$tpl_file=null,$cache_id=null,$compile_id=null){
switch($action){
case "read"://读取缓存内容
case "write"://写入缓存
case "clear"://清空
}
}