位置: 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视频教程)

  • 小规模纳税人执行小企业会计准则吗
  • 酒店摆放物品是什么
  • 文化建设费退税会计分录怎么做
  • 材料按实际成本计价时发出成本的计算方法有
  • 公司自有房产自用要交房产税吗
  • 建筑行业分包款要分项目扣除吗
  • 银行提备用金怎么提
  • 收到投资款需要缴纳增值税吗
  • 企业清算过程中应收应付的处置
  • 一般纳税人建账建几本帐
  • 集团财务公司资金管理
  • 减免税款的会计处理
  • 增值税销项税如何进行处理,有哪些种情况
  • 房地产企业的收入信息披露范围进一步扩大
  • 行政单位财务长期挂账处理办法
  • 3%税率是一般纳税人还是小规模
  • 代理进出口公司营销方式
  • 过路费抵扣税率是多少
  • 淘宝的电子发票怎么看
  • 劳务费开发票还要代扣代缴吗?
  • 业务招待费进项税额转出
  • 债务转为资本什么意思
  • 微信转账记录怎么加回好友?
  • mac版字体怎么安装
  • 贷款钱到账又被转出去
  • 交契税需要什么东西
  • aliapp.exe是什么意思
  • vue项目中技巧知识点
  • 小规模纳税人免征增值税政策
  • oracleupdate关联表
  • 简单实现php留言功能
  • vue父子组件生命周期钩子执行顺序
  • 网络安全网页设计作品构思
  • 微擎框架破解版v2.7.7
  • 出售自建不动产怎么交税
  • 收费公路通行费补费平台
  • 备用金管理方式
  • 上一年度的费用退回清算表怎么填
  • sql serverjdbc
  • 5万元买二手车能买什么价位的车
  • 车间劳保费计入什么科目
  • 红字发票还要交税吗
  • 地价计入房产原值文件解读
  • sql server数据库连接端口1434
  • centos彻底删除文件
  • 购买银行理财产品的几个必须知道
  • 生产设备改扩建会计分录
  • 如何降低未分配利润的方法
  • 母公司给子公司开票会有税务风险吗
  • 公司报销专用发票
  • 工程主营业务收入会计分录
  • 红字的记账凭证怎么记账
  • 客户退货,但不退货
  • 预提费用处理
  • 企业支付宝要手续费吗
  • 购车预付款交了可以退吗
  • 为什么营业成本属于费用
  • 添加网络打印机找不到设备
  • win8蓝屏代码大全
  • bios设置密码怎么设置
  • 如何在xp系统中调整移动硬盘
  • ubuntu装eclipse
  • speedupmypc.exe - speedupmypc是什么进程
  • mac声音怎么调大
  • linux修改服务器ip地址
  • rsync -i
  • servers.mcs
  • 无法装win7
  • 非常好的成语
  • 简述图像批处理的操作过程
  • unity3d物体移动代码
  • unity openvr
  • javascript语言基础
  • 基于javascript的毕业设计
  • js的iframe
  • android 分辨率适配
  • 黑马程序员培训怎样
  • python多线程技术
  • 税务局约谈记录
  • 河南省税务局系统最新消息
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设