ThinkPHP静态缓存简单配置和使用方法详解
本文实例讲述了thinkphp静态缓存简单配置和使用方法。分享给大家供大家参考,具体如下:
根据thinkphp官方手册:thinkphp内置了静态缓存类,通过静态缓存规则定义来实现了可配置的静态缓存。
启用静态缓存:
thinkphp官方手册写道
要使用静态缓存功能,需要开启html_cache_on 参数,并且在项目配置目录下面增加静态缓存规则文件 htmls.php,两者缺一不可。否则静态缓存不会生效。
在配置文件conf\config.php的array()中加上:
'html_cache_on' => true,//开启静态缓存 'html_path' => '__app__/html',//静态缓存文件目录,html_path可任意设置,此处设为当前项目下新建的html目录
静态规则定义:
thinkphp官方手册写道
静态规则的定义有三种方式:
return array( 'actionname'=>array('静态规则','静态缓存有效期','附加规则'), //第一种 'modulename:actionname'=>array('静态规则','静态缓存有效期','附加规则'),//第二种 '*'=>array('静态规则','静态缓存有效期','附加规则'),//第三种 …更多操作的静态规则 )
第一种是定义全局的操作静态规则,例如定义所有的read操作的静态规则为:
'read'=>array('{id}','60')
其中,{id} 表示取$_get['id'] 为静态缓存文件名,第二个参数表示缓存60秒。
第二种是定义某个模块的操作的静态规则,例如,我们需要定义blog模块的read操作进行静态缓存
'blog:read'=>array('{id}',-1)
第三种方式是定义全局的静态缓存规则,这个属于特殊情况下的使用,任何模块的操作都适用,例如
'*'=>array('{$_server.request_uri|md5}') //根据当前的url进行缓存。
我这里在静态缓存规则文件 htmls.php中写:
<?php return array( 'gethtml' => array('{:action}', -1),//-1表示永久缓存 ); ?>
上面的静态缓存规则表示定义所有的gethtml操作的静态规则为:
'gethtml'=>array('{:action}',-1)
{:action}表示当前操作名为静态缓存文件名。
同样在\lib\action\indexaction.class.php文件中写:
<?php class indexaction extends action{ //在当前项目的html目录下生成gethtml.shtml public function gethtml() { header('content-type:text/html;charset=utf-8'); $this->assign('title', '生成html文件'); $this->assign('info', '生成html文件'); $this->display(); } } ?>
在\tpl\default\index\gethtml.html中写:
<!doctype html public "-//w3c//dtd html 4.0 transitional//en"> <html> <head> <meta http-equiv="content-type" content="text/html;charset=utf-8" /> <title>{$title}</title> </head> <body> <h2>{$info}</h2> </body> </html>
然后在浏览器中输入:http://127.0.0.1/myapp/index.php/index/gethtml,可看到预期的页面。
刷新页面后,浏览器地址栏会发生变化,如下:
ps:如果用的apache,firefox和opera可能会不支持shtml文件,可以在httpd.conf文件中找到"addtype text/html .shtml","addoutputfilter includes .shtml",分别去掉前面的"#"即可。
更多关于thinkphp相关内容感兴趣的读者可查看本站专题:《thinkphp入门教程》、《thinkphp常用方法总结》、《smarty模板入门基础教程》及《php模板技术总结》。
希望本文所述对大家基于thinkphp框架的php程序设计有所帮助。