PHP模板引擎Smarty的缓存使用总结

大家应该都知道合理使用缓存能有效的减轻网站的服务器压力,php Smarty作为一个非常优秀的php模板引擎,它为我们提供了非常简单而多样化的缓存操作,下面就让我们学习一下smarty缓存操作方面的一些技巧。

这里我们将分析一下如何开启和使用smarty缓存,如何清除smarty缓存以及smarty的全局缓存,部分缓存,局部缓存三种缓存机制。

一、开启和使用smarty缓存

要开启smarty的缓存,只需在smarty设置参数里面将caching设为true,并指定cache_dir即可。同时设置cache_lefetime参数指定缓存生存时间(单位为秒)。如果要对相同页面生成多个不同的缓存,可以在display或fetch中加入第二参数cache_id,如:

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

此特性可用于对不同的$_GET进行不同的缓存。

二、清除smarty缓存

清除smarty缓存一般有以下几种方式:

  1. clear_all_cache();//清除所有缓存
  2. clear_cache('index.tpl');//清除指定模板index.tpl的缓存
  3. clear_cache('index.tpl',cache_id);//清除指定模板指定id的缓存

三、全局缓存

全局缓存就是为整个网站的全部页面都生成缓存页面。设置全局缓存首先我们要操作smarty的配置文件,开启缓存,指定缓存文件目录,并设置缓存的存活时间,设置参数如下:

  1. $smarty->cache_dir='./cache/'; //设置存放缓存文件的文件夹
  2. $smarty->caching=1;//开启缓存 0、FALSE代表关闭|非0数字、TRUE代表开启
  3. $smarty->cache_lifetime=3600//单位为秒(如果填写-1为永不过期)

接下来我们要去具体的php页面设置与之对应的具体缓存文件的名字,在php页面中可按如下写法:

$smarty->display('list2.html',md5($_SERVER['REQUEST_URI']));//将当前页面的URL(包含?后面的所有参数)进行md5加密然后设置缓存文件名

需要注意的是:

$smarty->display('与之对应的模板文件名','缓存文件名的补充部分')这个方法。

第二个参数不是必须的,如果不写的话,缓存文件名就是模板文件名经过加密处理后的文件。但是这样会碰到一个比较棘手的问题,例如:

https://www.phpfensi.com/article.php?id=5

https://www.phpfensi.com/article.php?id=7

这两个个URL对应应该的不同的内容,但是生成的缓存文件名都是 article 加密后的结果。这就会导致用户想要查询的是不同的内容,访问的却是同一个缓存文件。所以建议加上一个辅助参数,将访问url(包含?后面的所有参数)md5加密是比较靠谱的一种做法。

四、部分缓存

部分缓存就是指定一些文件生成缓存文件,而非网站的全部文件。部分缓存的实质其实是部分不缓存,也就是说不是指定哪些文件生成缓存,而是指定具体一些文件不生成缓存。现在假设有3个文件:

https://www.phpfensi.com/index.php //需要缓存

https://www.phpfensi.com/cate.php //需要缓存

https://www.phpfensi.com/article.php //不需要缓存

前面两个文件的php文件里面还是需要写上$smarty->display('与之对应的模板文件名','缓存文件名的补充部分')这句。

但在第三个文件中我们要特别指明不需要生成缓存,具体的方法是在display指定模板之前写上下面这段代码:

$smarty->clear_cache('与之对应的模板文件名');//其实写在$smarty->display('与之对应的模板文件名')之前还是之后都可以

当然$smarty->display('与之对应的模板文件名')还是要写,本来就不想生成缓存,第二个参数也就不需要了。

注意:$smarty->clear_cache()和$smarty->display()的参数一定要写成一致的

五、局部缓存

局部缓存就是指定同一页面下的某些局部地方生成缓存。其实它不是指定哪些局部生成缓存,而是哪些局部不生成缓存(这和部分缓存的操作思想是类似的)。我们先来看下面一个例子:

article.php 文件部分内容如下:

  1. <?php
  2. $time=time();
  3. $smarty->assign('time',$lanmuarr);
  4. function insert_timeget(){
  5. return time();
  6. }
  7. $smarty->display('article.html');

对应模板文件article.html部分代码如下:

  1. <body>
  2. {$time}<!--开启缓存后,重复刷新这个值不会变-->
  3. {insert name='timeget'}<!--开启缓存后,重复刷新这个值会变-->
  4. </body>

这里对上面的例子做一下解释:在PHP中我们只要定义了函数名为 insert_ (注意下划线)自定义补充名的自定义函数,在其中返回的值,不需要assign()方法传递,就能直接在模板页面中以{insert name='自定义补充名'}的方式调用,同时不会受到缓存的影响,而实时刷新。

另外补充的一下是如果你感觉使用 Smarty 缓存不够爽的话,还可以使用自定义缓存,如何使用自定义缓存呢?

这里需要设置cache_handler_func使用自定义的函数处理缓存,如:

  1. $smarty->cache_handler_func="myCache";
  2. function myCache($action,&$smarty_obj,&$cache_content,$tpl_file=null,$cache_id=null,$compile_id=null){
  3. switch($action){
  4. case "read"://读取缓存内容
  5. case "write"://写入缓存
  6. case "clear"://清空
  7. }
  8. }