国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > CMS > PhpCMS > 正文

【phpcms-v9】phpcms-v9的緩存結構

2024-09-10 07:15:51
字體:
來源:轉載
供稿:網友

這篇文章繼續介紹phpcms的緩存結構,我并沒有做深入的學習,但是phpcms的想法上卻是有他的過人之處,太令人折服了,這里分享phpcms緩存的一中實現方案.

/include/cache.func.php

這里最先主要是定義了一些phpcms的緩存函數,phpcms的緩存分為,表緩存,模型緩存,模型字段緩存,還有模塊緩存,首先這些都是基于表的緩存的.

最開始有一個函數:

  1. function cache_all() 
  2. @set_time_limit(600); 
  3. cache_common(); 
  4. cache_module(); 
  5. cache_model(); 
  6. cache_category(); 
  7. cache_area(); 
  8. cache_type(); 
  9. cache_member_group(); 
  10.     cache_role(); 
  11. cache_author(); 
  12. cache_keyword(); 
  13. cache_copyfrom(); 
  14. cache_pos(); 
  15.     cache_status(); 
  16. cache_workflow(); 
  17. tags_update(); 
  18. return TRUE; 

這個函數就調用一大堆的緩存函數來生成緩存的。

首先第一個函數 cache_common

大家可以看下面的注釋,是將 前綴名_model,前綴名_category ,前綴名_ module,前綴名,前綴名_type,前綴名_area,等等寫入到$CACHE數組的對應下表之中 (比如model 表的數據$CACHE["model"]=$arr,$arr為phpcms_model表的數據)

  1. function cache_common() 
  2. global $db
  3. $data = array(); 
  4. $result = $db->query("SELECT `module`,`name`,`path`,`url`,`iscore`,`version` FROM `".DB_PRE."module` WHERE `disabled`=0"); 
  5. while($r = $db->fetch_array($result)) 
  6.    if(!$r['path']) $r['path'] = $r['module'] == 'phpcms' ? '' : $r['module'].'/'
  7.    if(!$r['url']) $r['url'] = $r['module'] == 'phpcms' ? '' : $r['module'].'/'
  8.    $data[$r['module']] = $r
  9.  
  10. $db->free_result($result); 
  11. $CACHE['MODULE'] = $data
  12. //以上是將對應的模塊寫入$CACHE; 
  13.  
  14. $data = array(); 
  15. $result = $db->query("SELECT * FROM `".DB_PRE."model` WHERE `disabled`=0"); 
  16. while($r = $db->fetch_array($result)) 
  17.    $data[$r['modelid']] = $r
  18. $db->free_result($result); 
  19. $CACHE['MODEL'] = $data
  20. $data = array(); 
  21.  
  22. //以上是對應的 model表里的內容寫入數組$CACHE; 
  23.  
  24.  
  25. $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`"); 
  26. while($r = $db->fetch_array($result)) 
  27.    $r['url'] = url($r['url']); 
  28.    $data[$r['catid']] = $r
  29. $db->free_result($result); 
  30. $CACHE['CATEGORY'] = $data
  31. //以上是將所有的欄目寫入$CACHE數組 
  32.  
  33. $data = array(); 
  34. $result = $db->query("SELECT `typeid`,`modelid`,`module`,`name`,`style`,`typedir`,`url` FROM `".DB_PRE."type` WHERE 1 ORDER BY `listorder`,`typeid`"); 
  35. while($r = $db->fetch_array($result)) 
  36.    $data[$r['typeid']] = $r
  37. $db->free_result($result); 
  38. $CACHE['TYPE'] = $data
  39. //以上是將所有的 類別表里的數據寫入$CACHE 
  40.  
  41. $data = array(); 
  42. $result = $db->query("SELECT `areaid`,`name`,`style`,`parentid`,`arrparentid`,`child`,`arrchildid` FROM `".DB_PRE."area` WHERE 1 ORDER BY `listorder`,`areaid`"); 
  43. while($r = $db->fetch_array($result)) 
  44.    $data[$r['areaid']] = $r
  45. $db->free_result($result); 
  46. $CACHE['AREA'] = $data
  47.  
  48. //所有的地區表寫入$CACHE; 
  49.  
  50. $data = array(); 
  51. $result = $db->query("SELECT `urlruleid`,`urlrule` FROM `".DB_PRE."urlrule` WHERE 1 ORDER BY `urlruleid`"); 
  52. while($r = $db->fetch_array($result)) 
  53.    $data[$r['urlruleid']] = $r['urlrule']; 
  54. $db->free_result($result); 
  55. $CACHE['URLRULE'] = $data
  56.  
  57. //將所有的url規則寫入緩存 
  58.  
  59. $data = array(); 
  60.     $r = $db->get_one("SELECT `setting` FROM `".DB_PRE."module` WHERE `module`='phpcms'"); 
  61. $setting = $r['setting']; 
  62. eval("/$PHPCMS = $setting;"); 
  63. if($PHPCMS['siteurl'] ==''$PHPCMS['siteurl'] = SITE_URL; 
  64.  
  65. $CACHE['PHPCMS'] = $PHPCMS
  66. //開源軟件:Vevb.com 
  67. //最后調用cache_write方法將所有的數組寫入common.php 位置/date/cache/common.php根據系統變量慧有所改動 
  68.  
  69. cache_write('common.php'$CACHE); 
  70.      
  71. return $CACHE

phpcms表緩存的實現方式主要是:利用一個叫cache_table函數$table是要緩存的表名,$fileds 是查詢的字段名字,默認為 ' * ',$where sql語句中的where 子句,$order 排序,$isline是否開啟字段緩存默認為不開啟,如果開啟表字段緩存和表緩存將同時進行:

  1. function cache_table($table$fields = '*'$valfield = ''$where = ''$order = ''$iscacheline = 0, $number = 0) 
  2. global $db
  3. $keyfield = $db->get_primary($table); 
  4. $data = array(); 
  5. if($where$where = " WHERE $where"
  6. if(!$order$order = $keyfield
  7. $limit = $number ? "LIMIT 0,$number" : ''
  8. $result = $db->query("SELECT $fields FROM `$table` $where ORDER BY $order $limit"); 
  9. $table = preg_replace("/^".DB_PRE."(.*)$/"""$table); 
  10. while($r = $db->fetch_array($result)) 
  11.    if(isset($r['setting']) && !emptyempty($r['setting'])) 
  12.    { 
  13.     $setting = $r['setting']; 
  14.     eval("/$setting = $setting;");  
  15.     unset($r['setting']); 
  16.     if(is_array($setting)) $r = array_merge($r$setting); 
  17.         } 
  18.    $key = $r[$keyfield]; 
  19.    $value = $valfield ? $r[$valfield] : $r
  20.    $data[$key] = $value
  21.    if($iscacheline) cache_write($table.'_'.$key.'.php'$value); //表字段緩存 
  22. $db->free_result($result); 
  23. cache_write($table.'.php'$data) ;// 表緩存 
  24.  

將數據數組寫入對應的緩存文件,以上這個函數就是判斷下常量CACHE_PATH是否存在默認是data/cache的路徑然后用file_put_contents 將緩存的數據寫入到對應的cachefile中.

  1. function cache_write($file$array$path = ''
  2. if(!is_array($array)) return false; 
  3. $array = "<?php/nreturn ".var_export($array, true).";/n?>"
  4. $cachefile = ($path ? $path : CACHE_PATH).$file
  5. $strlen = file_put_contents($cachefile$array); 
  6. @chmod($cachefile, 0777); 
  7.  
  8. return $strlen

至于其他的可以參照以上的方法進行添加,大家可以查查看對應的cache.func.php:

  1. //緩存模型表 
  2. function cache_model() 
  3. cache_table(DB_PRE.'model''*''''''modelid', 1); 
  4. //緩存分類表生成文件路徑是../data/cachecategory_catid.php 
  5. function cache_category() 
  6. cache_table(DB_PRE.'category''*''''''listorder,catid', 1); 
  7. 緩存類別表生成路徑 
  8. ../data/cache/type_typeid.php 
  9. function cache_type() 
  10. cache_table(DB_PRE.'type''*''''''listorder,typeid', 1); 
  11. //緩存地區列表 
  12. 生成路徑:../data/cache/area_areaid.php 
  13. function cache_area() 
  14. cache_table(DB_PRE.'area''*''''''listorder,areaid', 1); 
  15. //緩存用戶組表 
  16. //生成路徑:../data/cache member_grounp_group_id.php 
  17. function cache_member_group() 
  18. cache_table(DB_PRE.'member_group''*''''''groupid', 1); 
  19. cache_table(DB_PRE.'member_group''*''name''''groupid', 0); 
  20. //緩存角色表 
  21. //生成路徑:../data/cache/role_roleid.php 
  22. function cache_role() 
  23. cache_table(DB_PRE.'role''*''name''''listorder,roleid'); 
  24. //緩存作者表 
  25. //生成路徑:../data/cache/author_authorid.php 
  26. function cache_author() 
  27. cache_table(DB_PRE.'author''*''name''''listorder,authorid', 0, 100); 
  28. function cache_keyword() 
  29. cache_table(DB_PRE.'keyword''*''tag''''listorder,usetimes', 0, 100); 
  30. function cache_copyfrom() 
  31. cache_table(DB_PRE.'copyfrom''*''''''listorder,usetimes', 0, 100); 
  32. function cache_pos() 
  33. cache_table(DB_PRE.'position''*''name''''listorder,posid', 0); 
  34. }

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 淳化县| 平武县| 深州市| 加查县| 鄂托克旗| 囊谦县| 弋阳县| 辰溪县| 雷山县| 开远市| 应城市| 林芝县| 河西区| 丰原市| 会宁县| 安丘市| 上虞市| 兰坪| 松原市| 桃园县| 河池市| 漳浦县| 凤山市| 佳木斯市| 深泽县| 京山县| 资阳市| 合水县| 扎赉特旗| 上蔡县| 河源市| 正安县| 花垣县| 固始县| 绩溪县| 双江| 孝义市| 宁波市| 南昌市| 电白县| 庄河市|