D:
/
virtualhost
/
localuser
/
host3914537801
/
www
/
core
/
basic
/
Upload File
HOME
<?php /** * @copyright (C)2016-2099 Hnaoyun Inc. * @author XingMeng * @email hnxsh@foxmail.com * @date 2017年11月4日 * 系统基础类 */ namespace core\basic; class Basic { protected static $models = array(); // 实现类文件自动加载 public static function autoLoad($className) { if (substr($className, 0, 4) == 'core') { // 框架类文件命名空间转换 $class_file = CORE_PATH . '/' . str_replace('\\', '/', substr($className, 5)) . '.php'; } elseif (substr($className, 0, 3) == 'app') { // 应用类文件命名空间转换 $class_file = APP_PATH . '/' . str_replace('\\', '/', substr($className, 4)) . '.php'; } elseif (strpos($className, '\\')) { // 如果带有命名空间,使用全路径载入 $class_file = ROOT_PATH . '/' . str_replace('\\', '/', $className) . '.php'; } else { // 默认载入内核基础目录下文件 $class_file = CORE_PATH . '/basic/' . $className . '.php'; } if (! file_exists($class_file)) { error('自动加载类文件时发生错误,类名【' . $className . '】,文件:【' . $class_file . '】'); } require $class_file; } // 自定义错误函数 public static function errorHandler($errno, $errstr, $errfile, $errline) { if (! (error_reporting() & $errno)) { // 如果这个错误类型没有包含在error_reporting里,如加了@的错误则不报告 return; } switch ($errno) { case E_ERROR: $err_level = 'ERROR'; break; case E_WARNING: $err_level = 'WARNING'; break; case E_PARSE: $err_level = 'PARSE'; break; case E_NOTICE: $err_level = 'NOTICE'; break; case E_RECOVERABLE_ERROR: case E_CORE_ERROR: case E_COMPILE_ERROR: case E_USER_ERROR: $err_level = 'FATAL ERROR'; break; default: $err_level = 'UNKNOW'; break; } $info = "<h3>$err_level:</h3>\n"; $info .= "<p><b>Code:</b> $errno;</p>\n"; $info .= "<p><b>Desc:</b> $errstr;</p>\n"; $info .= "<p><b>File:</b> $errfile;</p>\n"; $info .= "<p><b>Line:</b> $errline;</p>\n"; if ($err_level == 'WARNING' || $err_level == 'NOTICE') { echo $info; } else { error($info); } } // 异常捕获 public static function exceptionHandler($exception) { error("程序运行异常: " . $exception->getMessage() . ",位置:" . $exception->getFile() . ',第' . $exception->getLine() . '行。'); } // 致命错误捕获 public static function shutdownFunction() { $error = error_get_last(); define('E_FATAL', E_ERROR | E_RECOVERABLE_ERROR | E_CORE_ERROR | E_COMPILE_ERROR | E_USER_ERROR); if ($error && ($error["type"] === ($error["type"] & E_FATAL))) { $errno = $error["type"]; $errstr = $error["message"]; $errfile = $error["file"]; $errline = $error["line"]; self::errorHandler($errno, $errstr, $errfile, $errline); } } // 会话处理程序设置 public static function setSessionHandler() { if (ini_get('session.auto_start')) { return; } // 配置会话安全参数 session_name('PbootSystem'); ini_set("session.use_trans_sid", 0); ini_set("session.use_cookies", 1); ini_set("session.use_only_cookies", 1); session_set_cookie_params(0, SITE_DIR . '/', null, null, true); switch (Config::get('session.handler')) { case 'memcache': if (! extension_loaded('memcache')) error('PHP运行环境未安装memcache.dll扩展!'); ini_set("session.save_handler", "memcache"); ini_set("session.save_path", Config::get('seesion.path')); break; default: if (Config::get('session_in_sitepath')) { $save_path = RUN_PATH . '/session/'; if (! check_dir($save_path, true)) error('设置的会话目录创建失败!' . $save_path); ini_set("session.save_handler", "files"); $depth = 1; ini_set("session.save_path", $depth . ';' . $save_path); if (! is_dir($save_path . '/0/0') || ! is_dir($save_path . '/v/v')) { create_session_dir($save_path, $depth); } } break; } } // 实例化模型 public static function createModel($name = null, $new = false) { // 自动同名模型控制器 if (! $name) $name = C; // 获取类名 if (strpos($name, '.') !== false) { $path = explode('.', $name); $class_name = '\\app\\' . $path[0] . '\\model'; $len = count($path); for ($i = 1; $i < $len - 1; $i ++) { $class_name .= '\\' . $path[$i]; } $class_name .= '\\' . ucfirst($path[$i]) . 'Model'; } else { $class_name = '\\app\\' . M . '\\model\\' . ucfirst($name) . 'Model'; } // 根据需要实例化 $key = md5($class_name); if (! isset(self::$models[$key]) || $new) { self::$models[$key] = new $class_name(); } return self::$models[$key]; } // 创建数据接口 public static function createApi($args = null) { // 直接调用方式 if (! is_array($args)) { $args = func_get_args(); } // 分离参数 $name = $args[0]; unset($args[0]); $param = $args; // 如果只是传递了方法,则自动完善模块及模型控制器 if (strpos($name, '.') === false) { $name = M . '.' . C . '.' . $name; } $path = explode('.', $name); // 第一个为模块 $path[0],倒数第二个为模型$path[$i],倒数第一个为方法$path[$i+1] $class_name = '\\app\\' . $path[0] . '\\model'; $len = count($path); for ($i = 1; $i < $len - 2; $i ++) { $class_name .= '\\' . $path[$i]; } $class_name .= '\\' . ucfirst($path[$i]) . 'Model'; $key = md5($class_name); if (isset(self::$models[$key])) { $model = self::$models[$key]; } else { $model = new $class_name(); self::$models[$key] = $model; } // 调取接口方法 if (is_array($param)) { $rs = call_user_func_array(array( $model, $path[$i + 1] ), $param); } // 返回结果,如果不是json数据,则转换 if (! ! $return = json_decode($rs)) { return $rs; } else { return json_encode($rs); } } }