PHPCMS代码详细讲解 doc.doc

  1. 1、本文档共37页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
PHPCMS代码详细讲解 doc

PHPCMS 整站代码分析讲解(一) 首先我对 PHPCMS 的 头程序文件开始讲解 : include/common.inc.php? ?这个文件是程序启动的核心文件. [Copy to clipboard] [ - ] CODE: ?php /** 代码讲解分析: 逆雪寒. 2007 - 12 - 20 */ $mtime = explode( , microtime());?? $phpcms_starttime = $mtime[1] + $mtime[0]; /** 计算脚本开始运行的时间。很常见的写法。最后结算还在程序运行的终点位置。讲到了在给各位说。 */ unset($LANG, $_REQUEST, $HTTP_ENV_VARS, $HTTP_POST_VARS, $HTTP_GET_VARS, $HTTP_POST_FILES, $HTTP_COOKIE_VARS); /** 把??$HTTP_ENV_VARS $HTTP_POST_VARS 全局变量设置为 NULL??因为php4.1.0以上默认以 $_POST 来替代。unset后防止程序运行在低版本会出现安全等问题。比如变量注入 */ set_magic_quotes_runtime(0); //地球人都知道。关了字符窜入库自动转意 比如??my name is onx? ???转成??my name is on \x??为了最大的程序性能所以我们关掉吧~哈哈 define(IN_PHPCMS, TRUE); /** 程序入口标记。为什么需要这个东西呢。就好比你进一个小区,保安大哥哥肯定要你签字或是挂个鸟牌证明你是从正门进来的。 防止你翻墙进入去偷东西搞破坏。这个入口标记也有这个功能。 在这里定义了一个常量 IN_PHPCMS 为 TRUE ,然后我在其他程序文件里面检查这个标记。如果不存在或不为真, 那么就基本可以肯定你这个家伙是个小偷来的。 人可能翻墙进入。但程序怎么翻墙呢。只要在php.ini文件里面激活 allow_url_fopen选项,include() 就可以包含 URL 地址了。你想下如果你有个 放密码的PHP文件。如果给人家include 了以后。你怕不怕。 */ define(PHPCMS_ROOT, str_replace(\\, /, substr(dirname(__FILE__), 0, -8))); /** 为了程序产品的跨平台。自动获取程序的安装目录路径 ,定义为 PHPCMS_ROOT 常量。方便以后程序使用。建议大家都这样做哦 */ require PHPCMS_ROOT./include/global.func.php;?? /** 包含 全局函数 global.func.php 文件。里面放了些程序全局都有需要用的函数.大家看到了吧。??常量 PHPCMS_ROOT 已经发挥作用。 这样程序给人家发布到了 二级目录下。也不需要人家手动改整站根目录路径了。 自己好好理解下。。。。。 */ $search_arr = array(/ union /i,/ select /i,/ update /i,/ outfile /i,/ or /i); /** (/ union /i)??这个是正则的写法?不懂正则的自己百度找教程来学。 这里不详细说了 */ $replace_arr = array( union , select , update , outfile , or ); /** 看这个意思很明了。 union :连接两条SQL语句。 outfile : 主要用来导出数据库资料到其他介质上。 干啥字要定义这两个变量呢? 在 global.func.php 文件(前面已经加载)里面有个函数 strip_sql() 各位可以看下。 function strip_sql($string) { global $search_arr,$replace_arr; return is_array($string) ? array_map(strip_sql, $string) : preg_replace($search_arr, $replace_arr, $string); } 函数里面定义了这两个变量为 global全局变量。 那么函数里就可以直接使用了。??先讲解下这个函数吧。 顾名思义这个函数是过滤字符窜里面的SQL语句使得关键的SQL语句单词失效。 主要过滤那些SQL语句呢。 主要是这几个关键字: union??select??update outfile??or 等。因为这几个SQL字是极度容易在$_GET传输中给截注. 这个函数写得实在精妙。??is_array 来判断 $string 是否为数组。如

文档评论(0)

almm118 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档