##安装功能说明 我们在电脑上安装软件的时候,点击下一步调整一些配置选项软件就安装成功了。 不需要非常高深的计算机技术即可让普通人完成安装。 我们在真正的商业型产品中也需要做完整的安装过程: 1. 极为方便普通用户 2. 看起来特别专业 3. 操作起来简单提高效率 我们的PHP的论坛、商城、OA、微信平台都可以做这样的安装包,普通用户下载我们的安装包后。几步就可以开始使用我们的服务。 这样对用户和对开发人员都好。 ##安装相关基本概念 | 概念 | 说明 | | -- | -- | | 安装目录 | 通常在install目录下 | | 安装锁 | 通常为install.lock,有这个文件就是安装过,无这个文件就是未安装 | | PHP扩展模块判断 | mysqli模块没有就无法操作数据库,我们则拒绝用户继续安装 | | 目录权限判断 | 我们会写入install.lock或者一些临时文件,若某些目录没有写入修改权限则无法安装成功 | | 版本权限判断 | 如果是php4.x版本想安装我们的应用,我们会提醒用户PHP版本太低无法安装 | |超级管理员 | 初使的最高管理员,可以管理后台,方便用户管理,安装时即设置 | | 初始数据库结构|初始的数据库我们是将开发的数据库清空后,打开.sql文件,分行执行,向数据库写入创建表的语句和初始信息 | > 注:所有的代码文件实例请下载我们的安装包。查看install目录。 ##安装核心步骤说明 1. 打开网站。打开网站若不存在install.lock文件则识为未安装 2. 存在安装锁文件install.lock则禁止用户执行安装 3. 展示安装协议 4. 检测操作系统和PHP版本,是否版本准许。若版本不准许则不展示下一步。 5. 判断权限是否具备相关目录的写入权限和PHP的图像、数据库模块权限,若不具备相关权限则不显示下一步。 6. 输入服务器地址、数据库信息等配置文件,按照输入的信息连接数据库 7. 输入管理员信息 8. 将基本信息准备好,导入指定数据库数据表内容 9. 导入成功,创建一个空文件install.lock ##install.lock文件判断 在/common/common.php文件中有这么一段: ~~~ //项目安装 if(!file_exists('install.lock')) { header('location:install/index.php'); exit; } ~~~ 若文件不存在则跳转至header目录。停止继续向下执行 /install/top.php文件中有这一段: ~~~ if(file_exists('../install.lock')){ header('content-type:text/html; charset=utf-8;'); exit('网站已经被安装过了,如果需要重新安装网站,请删除 /install.lock 文件'); } ~~~ 若存在install.lock文件禁止执行安装步骤。 ##判断版本 获得操作系统版本 ~~~ function userOS(){ //$user_OSagent = $_SERVER['HTTP_USER_AGENT']; $user_OSagent = PHP_OS; if($user_OSagent) { $visitor_os = $user_OSagent; } else { $visitor_os = '其它'; } return $visitor_os; } ~~~ 获得PHP的版本号: ~~~ echo PHP_VERSION ~~~ ##判断目录权限 判断目录写入权限的自定义函数: ~~~ function iswriteable($file){ if(is_dir($file)){ $dir=$file; if($fp = fopen("$dir/test.txt", 'w')) { fclose($fp); unlink("$dir/test.txt"); $writeable = 1; }else{ $writeable = 0; } }else{ if($fp = fopen($file, 'a+')) { fclose($fp); $writeable = 1; }else { $writeable = 0; } } return $writeable; } ~~~ 判断模块权限: ~~~ function_exists('mysqli_connect') ~~~ 如果存在相关函数,则存在相关模块。 ##修改配置文件 相关代码参考本书:《8.11 修改置文件的实验》 ##数据库导入代码 将创建库的SQL语句准备好,创建数据库发送创建数据库的相关命令即可。 ~~~ //执行数据库导入 include '../config/database.php'; //新建数据库 $link = mysqli_connect(DB_HOST, DB_USER, DB_PASS); if(mysqli_get_server_info($link) > '4.1') { mysqli_query($link, "CREATE DATABASE IF NOT EXISTS `".DB_NAME."` DEFAULT CHARACTER SET ".DB_CHARSET); } else { mysqli_query($link, "CREATE DATABASE IF NOT EXISTS `".DB_NAME."`"); } if(mysqli_connect_errno($link)){ exit('数据库不存在'); } mysqli_close($link); ~~~ 导入数据库打开apple_bbs.sql准备好的SQL文件,这个SQL文件中每一行的行尾以;NoAlike结尾。 我们使用explode将sql文件切割成一个数组,循环数组的每一行完成数据的导入。 ~~~ $sql=file_get_contents('apple_bbs.sql'); $conn=mysqli_connect(DB_HOST, DB_USER, DB_PASS, DB_NAME); if(mysqli_errno($conn)){ exit(mysqli_error($conn)); } mysqli_set_charset($conn, DB_CHARSET); $arr=explode(';NoAlike;',$sql); foreach($arr as $val){ if(!empty($val)) { $Nval = str_replace('bbs_', DB_PREFIX, $val); $result = mysqli_query($conn, $Nval); if($result){ $sql = '<font color="green">数据库导入成功</font>'; }else{ $sql = '<font color="red">数据库导入失败</font>'; } } } mysqli_close($conn); ~~~ > 注:所有的代码文件实例请下载我们的安装包。查看install目录。