PHPCMS是采用MVC设计模式开发,基于模块和操作的方式进行访问,采用单一入口模式进行项目部署和访问,无论访问任何一个模块或者功能,只有一个统一的入口。
入口程序是在前期处理用户请求的引导程序。它是唯一一个可以被最终用户直接请求运行的。
PHPCMS V9的入口程序(index.php)如下:
第一行:定义项目的根路径,后面文件查找依赖此变量。
DIRECTORY_SEPARATOR(目录分隔符)是一个返回与操作系统相关的路径分隔符的内置命令,不需要任何定义与包含即可直接使用。由于windows上习惯性的使用\作为文件分隔符,但是在linux上人家是不认识这个标识的,人家只认识/,于是就要引入下面这个php内置常量:DIRECTORY_SEPARATOR。
第二行:根据项目根路径引入base.php文件,文件内容如下:
<?php
define('IN_PHPCMS', true);
define('PC_PATH', dirname(__FILE__).DIRECTORY_SEPARATOR);
if(!defined('PHPCMS_PATH')) define('PHPCMS_PATH', PC_PATH.'..'.DIRECTORY_SEPARATOR);
define('CACHE_PATH', PHPCMS_PATH.'caches'.DIRECTORY_SEPARATOR);
define('SITE_PROTOCOL', isset($_SERVER['SERVER_PORT']) && $_SERVER['SERVER_PORT'] == '443' ? 'https://' : 'http://');
define('SITE_URL', (isset($_SERVER['HTTP_HOST']) ? $_SERVER['HTTP_HOST'] : ''));
define('HTTP_REFERER', isset($_SERVER['HTTP_REFERER']) ? $_SERVER['HTTP_REFERER'] : '');
define('SYS_START_TIME', microtime());
pc_base::load_sys_func('global');
pc_base::load_sys_func('extention');
pc_base::auto_load_func();
pc_base::load_config('system','errorlog') ? set_error_handler('my_error_handler') : error_reporting(E_ERROR | E_WARNING | E_PARSE);
function_exists('date_default_timezone_set') && date_default_timezone_set(pc_base::load_config('system','timezone'));
define('CHARSET' ,pc_base::load_config('system','charset'));
header('Content-type: text/html; charset='.CHARSET);
define('SYS_TIME', time());
define('WEB_PATH',pc_base::load_config('system','web_path'));
define('JS_PATH',pc_base::load_config('system','js_path'));
define('CSS_PATH',pc_base::load_config('system','css_path'));
define('IMG_PATH',pc_base::load_config('system','img_path'));
define('APP_PATH',pc_base::load_config('system','app_path'));
define('PLUGIN_STATICS_PATH',WEB_PATH.'statics/plugin/');
if(pc_base::load_config('system','gzip') && function_exists('ob_gzhandler'))
{
ob_start('ob_gzhandler');
}
else
{
ob_start();
}
class pc_base
{
public static function creat_app()
{
return self::load_sys_class('application');
}
public static function load_sys_class($classname, $path = '', $initialize = 1)
{
return self::_load_class($classname, $path, $initialize);
}
public static function load_app_class($classname, $m = '', $initialize = 1)
{
$m = empty($m) && defined('ROUTE_M') ? ROUTE_M : $m;
if (empty($m))
return false;
return self::_load_class($classname, 'modules'.DIRECTORY_SEPARATOR.$m.DIRECTORY_SEPARATOR.'classes', $initialize);
}
public static function load_model($classname)
{
return self::_load_class($classname,'model');
}
private static function _load_class($classname, $path = '', $initialize = 1)
{
static $classes = array();
if (empty($path))
$path = 'libs'.DIRECTORY_SEPARATOR.'classes';
$key = md5($path.$classname);
if (isset($classes[$key]))
{
if (!empty($classes[$key]))
{
return $classes[$key];
}
else
{
return true;
}
}
if (file_exists(PC_PATH.$path.DIRECTORY_SEPARATOR.$classname.'.class.php'))
{
include PC_PATH.$path.DIRECTORY_SEPARATOR.$classname.'.class.php';
$name = $classname;
if ($my_path = self::my_path(PC_PATH.$path.DIRECTORY_SEPARATOR.$classname.'.class.php'))
{
include $my_path;
$name = 'MY_'.$classname;
}
if ($initialize)
{
$classes[$key] = new $name;
}
else
{
$classes[$key] = true;
}
return $classes[$key];
}
else
{
return false;
}
}
public static function load_sys_func($func)
{
return self::_load_func($func);
}
public static function auto_load_func($path='')
{
return self::_auto_load_func($path);
}
public static function load_app_func($func, $m = '')
{
$m = empty($m) && defined('ROUTE_M') ? ROUTE_M : $m;
if (empty($m))
return false;
return self::_load_func($func, 'modules'.DIRECTORY_SEPARATOR.$m.DIRECTORY_SEPARATOR.'functions');
}
public static function load_plugin_class($classname, $identification = '' ,$initialize = 1)
{
$identification = empty($identification) && defined('PLUGIN_ID') ? PLUGIN_ID : $identification;
if (empty($identification))
return false;
return pc_base::load_sys_class($classname, 'plugin'.DIRECTORY_SEPARATOR.$identification.DIRECTORY_SEPARATOR.'classes', $initialize);
}
public static function load_plugin_func($func,$identification)
{
static $funcs = array();
$identification = empty($identification) && defined('PLUGIN_ID') ? PLUGIN_ID : $identification;
if (empty($identification))
return false;
$path = 'plugin'.DIRECTORY_SEPARATOR.$identification.DIRECTORY_SEPARATOR.'functions'.DIRECTORY_SEPARATOR.$func.'.func.php';
$key = md5($path);
if (isset($funcs[$key]))
return true;
if (file_exists(PC_PATH.$path))
{
include PC_PATH.$path;
}
else
{
$funcs[$key] = false;
return false;
}
$funcs[$key] = true;
return true;
}
public static function load_plugin_model($classname, $identification)
{
$identification = empty($identification) && defined('PLUGIN_ID') ? PLUGIN_ID : $identification;
$path = 'plugin'.DIRECTORY_SEPARATOR.$identification.DIRECTORY_SEPARATOR.'model';
return self::_load_class($classname,$path);
}
private static function _load_func($func, $path = '')
{
static $funcs = array();
if (empty($path)) $path = 'libs'.DIRECTORY_SEPARATOR.'functions';
$path .= DIRECTORY_SEPARATOR.$func.'.func.php';
$key = md5($path);
if (isset($funcs[$key]))
return true;
if (file_exists(PC_PATH.$path))
{
include PC_PATH.$path;
}
else
{
$funcs[$key] = false;
return false;
}
$funcs[$key] = true;
return true;
}
private static function _auto_load_func($path = '')
{
if (empty($path)) $path = 'libs'.DIRECTORY_SEPARATOR.'functions'.DIRECTORY_SEPARATOR.'autoload';
$path .= DIRECTORY_SEPARATOR.'*.func.php';
$auto_funcs = glob(PC_PATH.DIRECTORY_SEPARATOR.$path);
if(!empty($auto_funcs) && is_array($auto_funcs))
{
foreach($auto_funcs as $func_path)
{
include $func_path;
}
}
}
public static function my_path($filepath)
{
$path = pathinfo($filepath);
if (file_exists($path['dirname'].DIRECTORY_SEPARATOR.'MY_'.$path['basename']))
{
return $path['dirname'].DIRECTORY_SEPARATOR.'MY_'.$path['basename'];
}
else
{
return false;
}
}
public static function load_config($file, $key = '', $default = '', $reload = false)
{
static $configs = array();
if (!$reload && isset($configs[$file]))
{
if (empty($key))
{
return $configs[$file];
}
elseif (isset($configs[$file][$key]))
{
return $configs[$file][$key];
}
else
{
return $default;
}
}
$path = CACHE_PATH.'configs'.DIRECTORY_SEPARATOR.$file.'.php';
if (file_exists($path))
{
$configs[$file] = include $path;
}
if (empty($key))
{
return $configs[$file];
}
else if (isset($configs[$file][$key]))
{
return $configs[$file][$key];
}
else
{
return $default;
}
}
}
base.php文件为框架入口文件,包含实例化系统/模块类方法,调用系统/模块方法,系统常用常量等。为了便于理解,现按顺序分四部分解析:
[1] 定义常量 IN_PHPCMS
在phpcms项目源码搜索关键字“IN_PHPCMS”,相关的代码语句有:
以及:
defined:是用来检查常量是否已定义。
注意:如果你要检查一个变量是否存在,请使用isset()。如果你要检查一个函数是否存在,使用function_exists()。defined()函数仅对constants常量有效:如果该名称的常量已定义,返回TURE;未定义则返回FALSE。
or:如果or前面的代码语句执行失败(或者返回false、0、null),那么执行or到其后第一个分号前面的代码(但双引号的分号不算);如果or前面的代码执行成功(或者返回true、非0、非null),那么不执行or到其后第一个分号前面的代码。
综上所述,phpcms为了代码不执行错误,每个执行文件都会判断是否包含了base.php文件,以减少错误。
[2] 定义PHPCMS框架路径、缓存文件夹地址
具体代码片段见上文base.php文件代码详细
__FILE__ 返回文件的完整路径和文件名。如果用在被包含文件中,则返回被包含的文件名。
__FILE__ 总是包含一个绝对路径(如果是符号连接,则是解析后的绝对路径,比如PHPCMS里面的 PC_PATH.’..’.DIRECTORY_SEPARATOR)
dirname(__FILE__) 函数返回的是脚本所在的路径,不会返回当前的文件名称。如果b.php包含了dirname(__FILE__)相关代码,同时b.php被其他目录里的a.php文件require或者include已用的话,返回的依然是b.php所在的那个文件夹路径,而不是变成a.php文件所在目录。
[3] 主机协议、当前访问的主机名、来源、系统开始时间
[4] 加载共用函数库
很显然,类中静态方法调用,具体执行步骤见类pc_base(上文base.php文件中)的函数。
头两句分别加载了/phpcms/libs/functions/global.func.php 和 /phpcms/libs/functions/extention.func.php文件。
global.func.php是共用函数库。
extension.func.php是用户自定义函数库。
之后一句是加载/phpcms/libs/functions/autoload/文件夹下面 *.func.php 文件(详见函数注释)。
第三行:pc_base是base.php定义的类,调用类方法create_app。
本文标签:
声明:本文由代码号注册/游客用户【凡旋】供稿发布,本站不对用户发布的PHPCMSV9框架代码分析信息内容原创度和真实性等负责。如内容侵犯您的版权或其他权益,请留言并加以说明。站长审查之后若情况属实会及时为您删除。同时遵循 CC 4.0 BY-SA 版权协议,尊重和保护作者的劳动成果,转载请标明出处链接和本声明内容。本文作者:凡旋» https://www.ebingou.cn/dmh/15466.html
很赞哦! (1)