123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168 |
- <?php
- /**
- * @copyright (C)2016-2099 Hnaoyun Inc.
- * @author XingMeng
- * @email hnxsh@foxmail.com
- * @date 2016年11月6日
- * 系统环境检查类
- */
- namespace core\basic;
-
- use core\basic\Config;
-
- class Check
- {
-
- // 启动应用检查
- public static function checkApp()
- {
- if (! is_dir(APP_PATH)) {
- error('您的系统文件无法正常读取,请检查是否上传完整!');
- }
-
- // 判断自动转换状态
- if (PHP_VERSION < '7.0' && function_exists("get_magic_quotes_gpc") && get_magic_quotes_gpc()) {
- error('您的服务器环境PHP.ini中magic_quotes_gpc配置为On状态,会导致数据存储异常,请设置为Off状态或切换为更高版本PHP。');
- }
-
- // 判断目录列表函数
- if (! function_exists('scandir')) {
- error('您的服务器环境PHP.ini配置中已经禁用scandir函数,会导致无法正常读取配置及模板文件,请先去除。');
- }
-
- // 检查gd扩展
- if (! extension_loaded('gd')) {
- error('您的服务器环境不支持gd扩展,将无法使用验证码!');
- }
-
- // 检查mbstring扩展
- if (! extension_loaded('mbstring')) {
- error('您的服务器环境不支持mbstring扩展,请先安装并启用!');
- }
-
- // 检查curl扩展
- if (! extension_loaded('curl')) {
- error('您的服务器环境不支持curl扩展,请先安装并启用!');
- }
- }
-
- // 检查PHP版本
- public static function checkPHP()
- {
- if (version_compare(phpversion(),'7.0.0','<')) {
- error('您服务器的PHP版本太低,本程序要求版本不小于 7.0');
- }
- }
-
- // 检查mysqli扩展库
- public static function checkMysqli()
- {
- if (! extension_loaded('mysqli')) {
- error('您的服务器环境不支持mysqli扩展,将无法正常使用数据库!');
- }
- }
-
- // 检查curl扩展库
- public static function checkCurl()
- {
- if (! extension_loaded('curl')) {
- error('您的服务器环境不支持curl扩展,将无法使用API模式!');
- }
- }
-
- // 目录路径检查,不存在时根据配置文件选择是否自动创建
- public static function checkBasicDir()
- {
- if (Config::get('debug')) {
- check_dir(APP_PATH, true);
- check_dir(APP_PATH . '/common', true);
- check_dir(CONF_PATH, true);
- }
-
- // 目录权限判断
- if (! check_dir(RUN_PATH, true)) {
- error('缓存目录创建失败,可能写入权限不足!' . RUN_PATH);
- }
- if (! check_dir(DOC_PATH . STATIC_DIR . '/upload', true)) {
- error('上传目录创建失败,可能写入权限不足!' . DOC_PATH . STATIC_DIR . '/upload');
- }
- }
-
- // 检查系统默认首页的文件是否存在,不存在进行自动创建
- public static function checkAppFile()
- {
- $apps = Config::get('public_app', true);
- check_dir(APP_CONTROLLER_PATH, true);
- check_file(CONF_PATH . '/config.php', true, "<?php \r\n return array(\r\n\t //'控制项'=>'值' 以分号,分割\r\n);");
- check_file(APP_CONTROLLER_PATH . '/IndexController.php', true, "<?php \r\r namespace app\\" . M . "\\controller;\r\r use core\\basic\\Controller; \r\r class IndexController extends Controller{\r\r\tpublic function index(){\r\t\t\$this->display('index.html');\r\t} \r\r}");
- check_file(APP_PATH . '/common/' . ucfirst(M) . 'Controller.php', true, "<?php \r\rnamespace app\\common;\r\ruse core\\basic\\Controller; \r\rclass " . ucfirst(M) . "Controller extends Controller{ \r\r}");
- // check_file(APP_PATH . '/common/' . ucfirst(M) . 'Model.php', true, "<?php \r\rnamespace app\\common;\r\ruse core\\basic\\Model; \r\rclass " . ucfirst(M) . "Model extends Model{ \r\r}");
- }
-
- // 检查客户端浏览器是否被允许,在同时设置黑白名单时,黑名单具有优先级更高,在设置了白名单时,将只允许白名单访问
- public static function checkBs()
- {
- $allow_bs = Config::get('access_rule.allow_bs', true);
- $deny_bs = Config::get('access_rule.deny_bs', true);
- // 都未设置时,直接通过
- if (! $allow_bs && ! $deny_bs)
- return true;
- // 客户端使用的系统
- $user_bs = get_user_bs();
- // 如果在黑名单则直接拒绝
- if (in_array($user_bs, $deny_bs)) {
- error('本站点设置了不允许' . $user_bs . '内核浏览器访问,请使用其它版本IE、火狐、谷歌等,国产浏览器请使用极速模式!');
- } elseif ($allow_bs && ! in_array($user_bs, $allow_bs)) {
- error('本站点设置了只允许' . implode(',', $allow_bs) . '内核浏览器访问,请使用这些浏览器!');
- }
- }
-
- // 检查客户端操作系统是否被允许,在同时设置黑白名单时,黑名单具有优先级更高,在设置了白名单时,将只允许白名单访问
- public static function checkOs()
- {
- $allow_os = Config::get('access_rule.allow_os', true);
- $deny_os = Config::get('access_rule.deny_os', true);
- // 都未设置时,直接通过
- if (! $allow_os && ! $deny_os)
- return true;
- // 客户端使用的系统
- $user_os = get_user_os();
- // 如果在黑名单则直接拒绝
- if (in_array($user_os, $deny_os)) {
- error('本站点设置了不允许' . $user_os . '访问,请使用其它操作系统!');
- } elseif ($allow_os && ! in_array($user_os, $allow_os)) {
- error('本站点设置了只允许' . implode(',', $allow_os) . '访问,请使用这些操作系统!');
- }
- }
-
- public static function checkSession(){
- /*$checkDir = check_dir(RUN_PATH . '/session',false);
- if($checkDir === true){
- $fileTime = filectime(RUN_PATH . '/session');
- $subDay = intval((time() - $fileTime) / 86400);
- if($subDay > 1){
- path_delete(RUN_PATH . '/session',true);
- }
- } */
- check_dir(RUN_PATH . '/archive', true);
- $data = json_decode(trim(substr(file_get_contents(RUN_PATH . '/archive/session_ticket.php'), 15)));
- if($data){
- if($data->expire_time && $data->expire_time < time()){
- ignore_user_abort(true);
- set_time_limit(7200);
- ob_start();
- ob_end_flush();
- flush();
- $rs = path_delete(RUN_PATH . '/session');
- if($rs){
- $data->expire_time = time() + 60 * 30 * 1; // 清理完成后将缓存清理时间延后30分钟
- create_file(RUN_PATH . '/archive/session_ticket.php', "<?php exit();?>".json_encode($data), true);
- }
- }
- }else{
- $start_time = time() + 60 * 60 * 1; // 初始化清理时间
- $start_str = '{"expire_time":' . $start_time . '}';
- create_file(RUN_PATH . '/archive/session_ticket.php', "<?php exit();?>" . $start_str, true);
- }
- }
- }
|