·设为首页收藏本站📧邮箱修改🎁免费下载专区🔐设置/修改密码👽群雄群聊
返回列表 发布新帖

Discuz! X系列,缓存扩展机制说明

154 1
发表于 2022-8-14 11:20:58 | 显示全部楼层 阅读模式

马上注册,免费下载更多dz插件网资源。

您需要 登录 才可以下载或查看,没有账号?立即注册

×
Discuz! X系列中加入了全新的缓存机制,我们在开发插件或者是增加新的功能的时候可以很方便的为系统增加一个全新的缓存,并在任何页面中使用。
下面以一个 名为 example 的缓存为例,详细说一下这个机制。

新建一个文件:
  1. <?phpif(!defined('IN_DISCUZ')) {        exit('Access Denied');}function build_cache_example() {        $data = array();    $data[] = 'Hello World';    $data[] = 'Hello Discuz!';        save_syscache('example', $data);}?>
复制代码
这就是一个标准的生成缓存的文件。其中有几点重要的为:
    需要生成名字为 example 的缓存,那么这个文件的名字需要命名为:cache_example.php文件中的 build_cache_xxxx 类似的这个函数名应为 build_cache_examplesave_syscache('xxxx', $data);  应该为  save_syscache('example', $data);为了安全性,文件头部必须增加
    1. if(!defined('IN_DISCUZ')) {        exit('Access Denied');}
    复制代码
其中 build_cache_example 函数就是主要的对需要缓存的数据做处理的函数,所有的组织数据,都可以放到这个函数里面执行,或者放到多个小函数,然后统一在这个函数中执行。而且结尾必须要以  save_syscache('example', $data); 结尾,才能写入缓存数据。

现在缓存文件有了,我们可以把 cache_example.php 文件放到 source/function/cache 目录中。这样在的 Discuz! 文件中就可以调用这个缓存了。
更新缓存的方法:
  1. require_once libfile('function/cache');updatecache('example');
复制代码
调用缓存的方法:
  1. require_once libfile('function/cache');loadcache('example');
复制代码
执行后,缓存在:$_G['cache']['example']  变量中;
测试代码:
  1. require_once libfile('function/cache');updatecache('example');loadcache('example');print_r($_G['cache']['example']);exit;
复制代码
输出结果:
  1. Array ( [0] => Hello World [1] => Hello Discuz! )
复制代码
请大家在开发插件或者增加功能的时候,为了自己和别人网站的稳定,为每个结果量很大的查询结果增加缓存~~
我要说一句 收起回复
一花一世界,一叶一追寻。一曲一场叹,一生为一人。

评论1

拾光Lv.8 发表于 2022-8-14 11:21:45 | 显示全部楼层
感谢分享!
我要说一句 收起回复

回复

 懒得打字嘛,点击右侧快捷回复【查看最新发布】   【应用商城享更多资源】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

投诉/建议联系

discuzaddons@vip.qq.com

未经授权禁止转载,复制和建立镜像,
如有违反,按照公告处理!!!
  • 联系QQ客服
  • 添加微信客服

联系DZ插件网微信客服|最近更新|Archiver|手机版|小黑屋|DZ插件网! ( 鄂ICP备20010621号-1 )|网站地图

您的IP:3.145.77.114,111.225.213.73,GMT+8, 2024-5-6 06:26 , Processed in 0.217110 second(s), 77 queries , Gzip On, Redis On.

Based on Discuz! W1.0 Licensed

© 2001-2024 Discuz! Team.

关灯 在本版发帖
扫一扫添加微信客服
QQ客服返回顶部
快速回复 返回顶部 返回列表