位置: IT常识 - 正文

phpcms v9缓存文件是怎样生成的(php文件缓存类)

编辑:rootadmin
phpcms v9缓存文件的生成方法:首先打开“cache.func.php”文件;然后通过“cache_all()”方法调用多个缓存函数来生成缓存即可,如“cache_common”函数、“cache_table”函数等等。

推荐整理分享phpcms v9缓存文件是怎样生成的(php文件缓存类),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:php cache缓存,php cache缓存,phpcms更新缓存 文件,php ob缓存,phpcms更新缓存 文件,php的缓存文件是什么格式,php自带缓存,php自带缓存,内容如对您有帮助,希望把文章链接给更多的朋友!

phpcms v9缓存文件是怎样生成的?

这篇文章介绍phpcms的缓存结构

我并没有做深入的学习,但是phpcms的想法上却是有他的过人之处,太令人折服了,这里分享phpcms缓存的一中实现方案

/include/cache.func.php

这里最先主要是定义了一些phpcms的缓存函数,phpcms的缓存分为,表缓存,模型缓存,模型字段缓存,还有模块缓存,首先这些都是基于表的缓存的。

phpcms v9缓存文件是怎样生成的(php文件缓存类)

最开始有一个函数

function cache_all(){@set_time_limit(600);cache_common();cache_module();cache_model();cache_category();cache_area();cache_type();cache_member_group();cache_role();cache_author();cache_keyword();cache_copyfrom();cache_pos();cache_status();cache_workflow();tags_update();return TRUE;}

这个函数就调用一大堆的缓存函数来生成缓存的。

首先第一个函数 cache_common

大家可以看下面的注释,是将 前缀名_model,前缀名_category ,前缀名_ module,前缀名,前缀名_type,前缀名_area,等等写入到$CACHE数组的对应下表之中 (比如model 表的数据$CACHE["model"]=$arr,$arr为phpcms_model表的数据)

function cache_common(){global $db;$data = array();$result = $db->query("SELECT `module`,`name`,`path`,`url`,`iscore`,`version` FROM `".DB_PRE."module` WHERE `disabled`=0");while($r = $db->fetch_array($result)){if(!$r['path']) $r['path'] = $r['module'] == 'phpcms' ? '' : $r['module'].'/';if(!$r['url']) $r['url'] = $r['module'] == 'phpcms' ? '' : $r['module'].'/';$data[$r['module']] = $r;}$db->free_result($result);$CACHE['MODULE'] = $data;//以上是将对应的模块写入$CACHE;$data = array();$result = $db->query("SELECT * FROM `".DB_PRE."model` WHERE `disabled`=0");while($r = $db->fetch_array($result)){$data[$r['modelid']] = $r;}$db->free_result($result);$CACHE['MODEL'] = $data;$data = array();//以上是对应的 model表里的内容写入数组$CACHE;$result = $db->query("SELECT `catid`,`module`,`type`,`modelid`,`catname`,`style`,`image`,`catdir`,`url`,`parentid`,`arrparentid`,`parentdir`,`child`,`arrchildid`,`items`,`citems`,`pitems`,`ismenu`,`letter` FROM `".DB_PRE."category` WHERE 1 ORDER BY `listorder`,`catid`");while($r = $db->fetch_array($result)){$r['url'] = url($r['url']);$data[$r['catid']] = $r;}$db->free_result($result);$CACHE['CATEGORY'] = $data;//以上是将所有的栏目写入$CACHE数组$data = array();$result = $db->query("SELECT `typeid`,`modelid`,`module`,`name`,`style`,`typedir`,`url` FROM `".DB_PRE."type` WHERE 1 ORDER BY `listorder`,`typeid`");while($r = $db->fetch_array($result)){$data[$r['typeid']] = $r;}$db->free_result($result);$CACHE['TYPE'] = $data;//以上是将所有的 类别表里的数据写入$CACHE$data = array();$result = $db->query("SELECT `areaid`,`name`,`style`,`parentid`,`arrparentid`,`child`,`arrchildid` FROM `".DB_PRE."area` WHERE 1 ORDER BY `listorder`,`areaid`");while($r = $db->fetch_array($result)){$data[$r['areaid']] = $r;}$db->free_result($result);$CACHE['AREA'] = $data;//所有的地区表写入$CACHE;$data = array();$result = $db->query("SELECT `urlruleid`,`urlrule` FROM `".DB_PRE."urlrule` WHERE 1 ORDER BY `urlruleid`");while($r = $db->fetch_array($result)){$data[$r['urlruleid']] = $r['urlrule'];}$db->free_result($result);$CACHE['URLRULE'] = $data;//将所有的url规则写入缓存$data = array();$r = $db->get_one("SELECT `setting` FROM `".DB_PRE."module` WHERE `module`='phpcms'");$setting = $r['setting'];eval("\$PHPCMS = $setting;");if($PHPCMS['siteurl'] =='') $PHPCMS['siteurl'] = SITE_URL;$CACHE['PHPCMS'] = $PHPCMS;//最后调用cache_write方法将所有的数组写入common.php 位置/date/cache/common.php根据系统变量慧有所改动cache_write('common.php', $CACHE);return $CACHE;}

phpcms表缓存的实现方式主要是:利用一个叫cache_table函数$table是要缓存的表名,$fileds 是查询的字段名字,默认为 ' * ',$where sql语句中的where 子句,$order 排序, $isline是否开启字段缓存默认为不开启,如果开启表字段缓存和表缓存将同时进行

function cache_table($table, $fields = '*', $valfield = '', $where = '', $order = '', $iscacheline = 0, $number = 0){global $db;$keyfield = $db->get_primary($table);$data = array();if($where) $where = " WHERE $where";if(!$order) $order = $keyfield;$limit = $number ? "LIMIT 0,$number" : '';$result = $db->query("SELECT $fields FROM `$table` $where ORDER BY $order $limit");$table = preg_replace("/^".DB_PRE."(.*)$/", "", $table);while($r = $db->fetch_array($result)){if(isset($r['setting']) && !empty($r['setting'])){$setting = $r['setting'];eval("\$setting = $setting;");unset($r['setting']);if(is_array($setting)) $r = array_merge($r, $setting);}$key = $r[$keyfield];$value = $valfield ? $r[$valfield] : $r;$data[$key] = $value;if($iscacheline) cache_write($table.'_'.$key.'.php', $value); //表字段缓存}$db->free_result($result);cache_write($table.'.php', $data) ;// 表缓存}

将数据数组写入对应的缓存文件,以上这个函数就是判断下常量CACHE_PATH是否存在默认是data/cache的路径然后用file_put_contents 将缓存的数据写入到对应的cachefile中

function cache_write($file, $array, $path = ''){if(!is_array($array)) return false;$array = "<?php\nreturn ".var_export($array, true).";\n?>";$cachefile = ($path ? $path : CACHE_PATH).$file;$strlen = file_put_contents($cachefile, $array);@chmod($cachefile, 0777);return $strlen;}

至于其他的可以参照以上的方法进行添加,大家可以查查看对应的cache.func.php

//缓存模型表function cache_model(){cache_table(DB_PRE.'model', '*', '', '', 'modelid', 1);}//缓存分类表生成文件路径是../data/cachecategory_catid.phpfunction cache_category(){cache_table(DB_PRE.'category', '*', '', '', 'listorder,catid', 1);}

缓存类别表生成路径

../data/cache/type_typeid.phpfunction cache_type(){cache_table(DB_PRE.'type', '*', '', '', 'listorder,typeid', 1);}//缓存地区列表

生成路径:../data/cache/area_areaid.php

function cache_area(){cache_table(DB_PRE.'area', '*', '', '', 'listorder,areaid', 1);}//缓存用户组表//生成路径:../data/cache member_grounp_group_id.phpfunction cache_member_group(){cache_table(DB_PRE.'member_group', '*', '', '', 'groupid', 1);cache_table(DB_PRE.'member_group', '*', 'name', '', 'groupid', 0);}//缓存角色表//生成路径:../data/cache/role_roleid.phpfunction cache_role(){cache_table(DB_PRE.'role', '*', 'name', '', 'listorder,roleid');}//缓存作者表//生成路径:../data/cache/author_authorid.phpfunction cache_author(){cache_table(DB_PRE.'author', '*', 'name', '', 'listorder,authorid', 0, 100);}function cache_keyword(){cache_table(DB_PRE.'keyword', '*', 'tag', '', 'listorder,usetimes', 0, 100);}function cache_copyfrom(){cache_table(DB_PRE.'copyfrom', '*', '', '', 'listorder,usetimes', 0, 100);}function cache_pos(){cache_table(DB_PRE.'position', '*', 'name', '', 'listorder,posid', 0);}

PHP中文网,大量的免费PHPCMS教程,欢迎在线学习!

本文链接地址:https://www.jiuchutong.com/zhishi/310149.html 转载请保留说明!

上一篇:利用Python的Matplotlib库进行数据可视化(python.mat)

下一篇:帝国cms怎么百度自动提交(帝国cms视频教程)

  • 税务师财务与会计难不难
  • 递延所得税资产和递延所得税负债
  • 其他应付款不用付了会计分录
  • 计提工资时金额是应发工资还是实发工资
  • 跨年调整会计科目怎么写
  • 个体工商户出租商铺个人所得税
  • 零售行业的销售员有加班费吗
  • 固定资产替换公式
  • 向境外支付特许权使用费免征增值税
  • 收到结算单应该怎么处理
  • 增值税专用发票和普通发票的区别
  • 辅助生产车间最后结转到哪里
  • 全额拨款事业单位工资都一样吗
  • 醋开票属于什么类
  • 经济社会中民商是什么
  • 销售退回怎么开票
  • 印花税征税范围包括所有合同
  • 坏账准备核销和转销的区别
  • 二手店铺转让手续流程
  • 一般纳税人资格证明在哪里开具
  • 转让无形资产税目征收营业税的是
  • office已经激活
  • 预付款退还的法律规定
  • 备用金的会计分类
  • 总分类账是什么的依据
  • 个人所得税和企业所得税都要交吗
  • php输出mysql查询结果
  • php实现的中秋博饼游戏之掷骰子并输出结果功能详解
  • PHP CURL或file_get_contents获取网页标题的代码及两者效率的稳定性问题
  • 预收账款什么时候确认
  • 原材料科目是什么意思
  • phpwhile循环多维数组
  • php的laravel框架答辩
  • 办公费抵扣标准
  • php array_search二维数组
  • 深度学习实战(十):使用 PyTorch 进行 3D 医学图像分割
  • node.js教程详细
  • 开具增值税专用发票是什么意思
  • 长期待摊费用是资产
  • 公司注册资金表格模板
  • g郭敬明
  • php接口怎么调用
  • mysql常见报错
  • 费用多报销了,但已经给了,怎么办
  • 人力资源劳务外包需要什么资质证书
  • 进项认证以后如何处理
  • 未分配利润为负数可以分红吗
  • 固定成本和变动成本举例
  • 研发费用按50%的预算
  • 费用报销冲抵借支
  • 出口退税备案完事了,为什么还没有退税勾选那个模块
  • 固定成本包括哪些项目
  • 建账及账务处理步骤
  • 投资管理工作内容
  • cmd提示符基础知识
  • win7资源管理器未响应怎么办
  • unix操作系统命令
  • bios术语
  • linux用户空间获取TCP序号
  • Ubuntu 14.04安装java的方法以Ubuntu14.04为例
  • win7视频播放不了
  • frontpage软件
  • linux的命令行界面
  • win8隐藏的文件夹怎么找出来
  • fragment懒加载原理
  • cocos2dx屏幕适配解决方案
  • 复制文件到c盘需要管理员权限
  • css中层叠的含义
  • 仿百度首页
  • ubuntu20.04 python
  • javascript绘制图形
  • 用python语言编写
  • 湖南国家税务局网上电子税务局官网
  • 重庆国税12366电子税务局官网入口
  • 北京大兴国税局领导班子
  • 怎么撤销税务三方协议
  • 河北省2021城乡居民医保优惠新政策
  • 河南车船税收费标准2022年
  • 银行收取手续费可以抵扣进项税额吗
  • 江苏税务法人实名采集怎么操作流程
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设