大概的讲一下,有关zblogphp主题开发时候用到的缓存调用,可以减少大量的数据库请求,加快网站打开速度。
我们都知道,网站一般由首页、列表页、文章页,这三块组成,有些网站首页和列表页是一样的,常见于博客主题,当然也有首页和列表页不一样的,像cms主题,企业主题等,当然网站不仅仅像我说的只有这三种页面,再多页面的也都有,但是我们也知道,一个页面里面内容很多,都是需要我们在模板里面写函数,从数据库里面调用出来,才可以正常使用的,当一个页面比较复杂时候(常见于cms主题或企业主题),页面很多地方都进行各种数据库查询的时候,就会造成网站访问速度变慢。具体的,如果使用zblogphp版本的朋友们,可以鼠标右键点击页面,查看源代码,拖到最下面,可以看到一条类似这样的东西:
这个是我小锋博客的,因为使用的是php7.1,所以在页面大小上面显示有误,变负数了,主要是看前面的ms和query。(当然,如果大家看我的博客,可能看到的是接近0的ms,和0 query,这是因为我使用了别的缓存插件,这个后面再说。)下面看看具体操作流程。
实现方法
一般很多地方的调用数据,都不是动态调用,数据如果有改变,那一般是由于新建了文章导致的,所以我们可以在编辑文章,提交保存的时候调用我们所需的数据,然后往某个地方生成一个静态文件,这样的话,我们在模板里面直接调用这个静态文件即可,这样就不会再次请求数据库了。(这点类似动态页面与静态页面,动态页面在每次访问的时候,都会带着参数去请求数据库,得到内容后返回再给大家展示,而静态,是已经请求数据库获得内容后缓存下来的静态文件,直接访问即可,这样相对来说速度就会快很多。)
具体操作
以缓存前6篇最近更新的文章作为例子,在主题目录下的include.php文件中,加入下面这个函数代码:function 主题ID_RecentUpdates(&$article){
global $zbp;
$RecentUpdates = $zbp->GetArticleList('*', array(array('=', 'log_Type', 0), array('=', 'log_Status', 0)), array('log_PostTime' => 'DESC'), 6, null,false);
$str = '';
foreach ($RecentUpdates as $UpdatesArticle){
$str .= '
Url.'" title="'.$UpdatesArticle->Title.'" >'.$UpdatesArticle->Title.'';}
@file_put_contents($zbp->usersdir . 'theme/'.$zbp->theme.'/include/RecentUpdates.php', $str);
}
然后在主题目录下的include.php文件中找到ActivePlugin_主题ID这个函数,在里面给上面的函数挂载接口:Add_Filter_Plugin('Filter_Plugin_PostArticle_Succeed','主题ID_RecentUpdates');
这样就算完成了。
这时候随便打开一篇文章,什么都不用修改,直接点提交保存,这样会在主题目录下的include文件夹里面,生成一个名为RecentUpdates.php的文件。
在模板文件中,我们可以直接用{module:RecentUpdates}标签来调用RecentUpdates.php文件里面的内容,注意咯,文件名跟标签里面的名字是相同的。
其他说明
上面例子中,“主题ID”根据自己实际去修改,不要直接复制粘贴过去使用,不然必定报错。
通过上面的操作,我们在提交保存文章的时候,就可以获取6篇最近更新的文章,并且保存在主题目录/include文件夹里面,这样的话,我们在模板里面无需再次查询数据库来获取内容,而是直接调用这个文件即可,这样就达到了一个缓存的目的。
关于缓存插件,之前zblog应用中心是有一个缓存插件的,作者是鸟儿,但是由于某些问题,插件被下架了,所以现在搜索不出来。。
另外,我并不是大牛,上面很多东西我是个人理解后说出来的,有些地方说得不够专业或者有误,大神轻喷,欢迎点评。
×
选择打赏方式:
微信 QQ钱包 支付宝
打赏
打赏
打赏
多少都是心意,谢谢大家!!!
×
选择分享方式:
微信扫一扫,分享朋友圈
Or
手机扫一扫,精彩随身带