array('操作系统', '不限制', '类Unix', PHP_OS, 'check'), 'php' => array('PHP版本', '5.6', '5.6+', PHP_VERSION, 'check'), 'upload' => array('附件上传', '不限制', '2M+', '未知', 'check'), 'gd' => array('GD库', '2.0', '2.0+', '未知', 'check'), 'disk' => array('磁盘空间', '100M', '不限制', '未知', 'check'), ); // PHP环境检测 if($items['php'][3] < $items['php'][1]){ $items['php'][4] = 'times text-warning'; session('error', true); } // 附件上传检测 if(@ini_get('file_uploads')) $items['upload'][3] = ini_get('upload_max_filesize'); // GD库检测 $tmp = function_exists('gd_info') ? gd_info() : array(); if(empty($tmp['GD Version'])){ $items['gd'][3] = '未安装'; $items['gd'][4] = 'times text-warning'; session('error', true); } else { $items['gd'][3] = $tmp['GD Version']; } unset($tmp); // 磁盘空间检测 if(function_exists('disk_free_space')) { $disk_size = floor(disk_free_space(Env::get('app_path')) / (1024*1024)); $items['disk'][3] = $disk_size.'M'; if ($disk_size < 100) { $items['disk'][4] = 'times text-warning'; session('error', true); } } return $items; } /** * 目录,文件读写检测 * @return array 检测数据 */ function check_dirfile(){ $items = array( array('dir', '可写', 'check', '../application'), array('dir', '可写', 'check', '../config'), array('dir', '可写', 'check', '../data'), array('dir', '可写', 'check', '../export'), array('dir', '可写', 'check', '../packet'), array('dir', '可写', 'check', '../plugins'), array('dir', '可写', 'check', './static'), array('dir', '可写', 'check', './uploads'), array('dir', '可写', 'check', '../runtime'), array('dir', '可写', 'check', '../store'), ); foreach ($items as &$val) { $item = INSTALL_APP_PATH . $val[3]; if('dir' == $val[0]){ if(!is_writable($item)) { if(is_dir($item)) { $val[1] = '可读'; $val[2] = 'times text-warning'; session('error', true); } else { $val[1] = '不存在'; $val[2] = 'times text-warning'; session('error', true); } } } else { if(file_exists($item)) { if(!is_writable($item)) { $val[1] = '不可写'; $val[2] = 'times text-warning'; session('error', true); } } else { if(!is_writable(dirname($item))) { $val[1] = '不存在'; $val[2] = 'times text-warning'; session('error', true); } } } } return $items; } /** * 函数检测 * @return array 检测数据 */ function check_func(){ $items = array( array('pdo','支持','check','类'), array('pdo_mysql','支持','check','模块'), array('fileinfo','支持','check','模块'), array('curl','支持','check','模块'), array('file_get_contents', '支持', 'check','函数'), array('mb_strlen', '支持', 'check','函数'), array('scandir', '支持', 'check','函数'), ); foreach ($items as &$val) { if(('类'==$val[3] && !class_exists($val[0])) || ('模块'==$val[3] && !extension_loaded($val[0])) || ('函数'==$val[3] && !function_exists($val[0])) ){ $val[1] = '不支持'; $val[2] = 'times text-warning'; session('error', true); } } return $items; } /** * 写入配置文件 * @param $config * @return array 配置信息 */ function write_config($config){ if(is_array($config)){ //读取配置内容 $conf = file_get_contents(Env::get('app_path') . 'install/data/database.tpl'); // 替换配置项 foreach ($config as $name => $value) { $conf = str_replace("[{$name}]", $value, $conf); } //写入应用配置文件 if(file_put_contents(Env::get('config_path') . 'database.php', $conf)){ show_msg('配置文件写入成功'); } else { show_msg('配置文件写入失败!', 'error'); session('error', true); } return ''; } } /** * 创建数据表 * @param $db 数据库连接资源 * @param string $prefix 表前缀 */ function create_tables($db, $prefix = ''){ // 读取SQL文件 $sql = file_get_contents(Env::get('app_path') . 'install/data/dolphin.sql'); $sql = str_replace("\r", "\n", $sql); $sql = explode(";\n", $sql); // 替换表前缀 $orginal = config('original_table_prefix'); $sql = str_replace(" `{$orginal}", " `{$prefix}", $sql); // 开始安装 show_progress('0%'); $all_table = config('install_table_total'); $i = 1; foreach ($sql as $value) { $value = trim($value); if(empty($value)) continue; $msg = (int)($i/$all_table*100) . '%'; if(false !== $db->execute($value)){ show_progress($msg); } else { show_progress($msg, 'error'); session('error', true); } $i++; } } /** * 更新数据表 * @param $db 数据库连接资源 * @param string $prefix 表前缀 */ function update_tables($db, $prefix = ''){ //读取SQL文件 $sql = file_get_contents(Env::get('app_path') . 'install/data/update.sql'); $sql = str_replace("\r", "\n", $sql); $sql = explode(";\n", $sql); // 替换表前缀 $sql = str_replace(" `dp_", " `{$prefix}", $sql); //开始安装 show_progress('0%'); $all_table = config('update_data_total'); $i = 1; $msg = ''; foreach ($sql as $value) { $value = trim($value); if(empty($value)) continue; if(substr($value, 0, 12) == 'CREATE TABLE') { $msg = (int)($i/$all_table*100) . '%'; if(($db->execute($value)) === false){ session('error', true); } } else { if(substr($value, 0, 8) == 'UPDATE `') { $msg = (int)($i/$all_table*100) . '%'; } else if(substr($value, 0, 11) == 'ALTER TABLE'){ $msg = (int)($i/$all_table*100) . '%'; } else if(substr($value, 0, 11) == 'INSERT INTO'){ $msg = (int)($i/$all_table*100) . '%'; } if(($db->execute($value)) === false){ session('error', true); } } if ($msg != '') { show_progress($msg); $i++; } } } /** * 及时显示提示信息 * @param string $msg 提示信息 * @param string $class 类名 */ function show_msg($msg, $class = ''){ echo ""; flush(); ob_flush(); } /** * 显示进度 * @param $msg * @param string $class * @author 蔡伟明 <314013107@qq.com> */ function show_progress($msg, $class = ''){ echo ""; flush(); ob_flush(); }