导航

./upload/source/class/class_core.php

Posted on 2016-03-04 16:02  乐军  阅读(728)  评论(0编辑  收藏  举报

定义了core这个类

 

error_reporting(E_ALL);

error_reporting() 设置 PHP 的报错级别并返回当前级别。可以参考手册。

 

 

define('IN_DISCUZ', true);
define('DISCUZ_ROOT', substr(dirname(__FILE__), 0, -12));
define('DISCUZ_CORE_DEBUG', false);
define('DISCUZ_TABLE_EXTENDABLE', false);

定义了4个常量,他们的作用是:

in_discuz: true 表示可以通过这个文件去访问其他文件,否则不能独立去访问某些文件。

比如,其他的某个文件开头:该文件就是不能直接或者单独被访问的。  

if(!defined('IN_DISCUZ')) {
    exit('Access Denied');
}

 

discuz_root: 得到class_core.php所在的根目录,即source文件夹所在的目录( source/class 刚好12个字符)。

  dirname(): 返回路径中的目录部分,即一个完整的路径,去掉文件名的部分,类似的还有

  basename() - 返回路径中的文件名部分

  pathinfo() - 返回文件路径的信息

  realpath() - 返回规范化的绝对路径名

  举例说明: __FILE__ = F:\php-projects\Discuz32\upload\forum.php

  那么 dirname() = F:\php-projects\Discuz32\uploadbasename() = forum.php

  pathinfo() 是个array 

array (size=4)
  'dirname' => string 'F:\php-projects\Discuz32\upload' (length=31)
  'basename' => string 'forum.php' (length=9)
  'extension' => string 'php' (length=3)
  'filename' => string 'forum' (length=5)

 

   DISCUZ_CORE_DEBUG: 设置core类的debug是否开启,默认是false,如果需要调试,可以手动改为true。下面紧接着就用到了。

  DISCUZ_TABLE_EXTENDABLE: 未知

 

set_exception_handler(array('core', 'handleException'));

设置用户自定义的异常处理函数。参数是一个数组的话,那说明这个数组的第一个元素是类名或对象名称,第二个元素是方法名
如果发生未被捕获的exception的时候,调用core类中的handleException方法。
函数的用途: http://www.w3school.com.cn/php/func_error_set_exception_handler.asp

 

 

if(DISCUZ_CORE_DEBUG) {
    set_error_handler(array('core', 'handleError'));
    register_shutdown_function(array('core', 'handleShutdown'));
}

从上面看出,默认core的debug是关闭的,如果为true,则调用用户自定义的错误处理程序, core类的handleError方法。

 register_shutdown_function()介绍:so,这个函数不管是程序执行完毕还是程序执行出错,最后总是会回调我们写的demo函数。好了,我们可以利用这个特性写一个专门记录程序执行错误、记录日志的函数。参考:http://blog.csdn.net/phpwish/article/details/7857917

 

 

if(function_exists('spl_autoload_register')) {
    spl_autoload_register(array('core', 'autoload'));
} else {
    function __autoload($class) {
        return core::autoload($class);
    }
}

 function_exists() 检测spl_autoload_register函数是否存在,存在的话,当new core的时候,调用 core::autoload方法来实例化core;否则执行 __autoload()函数实例化,其实也是调用core::autoload方法。

至于spl_autoload_register 和 __autoload 函数的详细解释,参加:http://blog.csdn.net/panpan639944806/article/details/23192267

 

core::autoload方法如下:

public static function autoload($class) {
        $class = strtolower($class);
        if(strpos($class, '_') !== false) {
            list($folder) = explode('_', $class);
            $file = 'class/'.$folder.'/'.substr($class, strlen($folder) + 1);
        } else {
            $file = 'class/'.$class;
        }

        try {

            self::import($file);
            return true;

        } catch (Exception $exc) {

            $trace = $exc->getTrace();
            foreach ($trace as $log) {
                if(empty($log['class']) && $log['function'] == 'class_exists') {
                    return false;
                }
            }
            discuz_error::exception_error($exc);
        }
    }

 

 $class 通过 ‘_’被分割成2部分,前面的是文件夹,后面的是文件名。$file = ./class/.../文件名

 然后导入所需的文件。如果导入出现exception,则处理之。