##安装功能说明
我们在电脑上安装软件的时候,点击下一步调整一些配置选项软件就安装成功了。
不需要非常高深的计算机技术即可让普通人完成安装。
我们在真正的商业型产品中也需要做完整的安装过程:
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目录。
- 01. 为什么选择本书学习PHP
- 1.1 为什么学习PHP?
- 1.2 PHP是什么
- 1.3 零基础也能学习
- 1.4 为什么有些人学不会
- 02.PHP的环境安装
- 2.1开发环境是什么?
- 2.2 windows环境安装
- 2.3 Linux环境安装
- 2.4 其他开发环境
- 2.5 写代码的工具选择
- 03. PHP基本语法
- 3.1 PHP基本语法
- 3.1.1 写出你的第一段PHP代码
- 3.1.2 读过初中你就会变量
- 3.1.3 echo 显示命令
- 3.1.4 注释的功能很强大
- 3.2 数据类型并不神秘
- 3.2.1 整型就是整数
- 3.2.2 布尔就是易经的知识
- 3.2.3 字符串
- 3.2.4 浮点型
- 3.2.5 重要:if和else语法
- 3.2.6 NULL类型
- 3.2.7对象以后会学
- 3.2.8 数组会有单纯的一个章节
- 3.2.9 资源类型
- 3.2.10 眼前了解回调类型即可
- 3.2.11 查看和判断数据类型
- 3.2.12 数据类型的自动转换和强制转换
- 3.3 常量和变量
- 3.3.1 用常量限制用户跳过某些文件
- 3.3.2 可变变量
- 3.3.3 外部变量
- 3.3.4 环境变量
- 3.3.5 变量引用
- 3.4 PHP表达式与运算符
- 3.4.1 算术运算
- 3.4.2 赋值运算
- 3.4.3 自加、自减运算
- 3.4.4 比较运算
- 3.4.5 逻辑运算
- 3.4.6 位运算
- 3.4.7 运算符优先级
- 3.4.8 三元运算符和其它运算符
- 04. PHP中的流程控制
- 4.1 if条件结构流程
- 4.1.1 if语句
- 4.1.2 嵌套if...else...elseif结构
- 4.1.3 if语句多种嵌套
- 4.2 分支结构switch语句的使用
- 4.3 循环语句的使用
- 4.3.1 while循环
- 4.3.2 do...while循环的区别
- 4.3.3 for循环控制语句
- 4.3.4 goto语法
- 4.3.5 declare 语法
- 05.PHP的函数基本语法
- 5.1 自定义函数
- 5.2 自定义函数高级调用
- 5.2.1 回调函数
- 5.2.2 变量函数
- 5.2.3 匿名函数
- 5.2.4 内部函数
- 5.2.5 变量作用域
- 5.2.6 参数的引用
- 5.2.7 递归函数
- 5.2.8 静态变量
- 5.3 使用系统内置函数
- 5.4 文件包含函数
- 5.5 数学常用函数
- 5.6 日期常用函数
- 5.6.1 获取时期时间信息函数
- 5.6.2 日期验证函数
- 5.6.3 获取本地化时间戳函数
- 5.6.4 程序执行时间检测
- 5.7 字符串常用函数
- 06.PHP数组与数据结构
- 6.1 数组的定义
- 6.2 数组的操作
- 6.2.1 数组的计算
- 6.2.2 for循环遍历索引数组
- 6.2.3 foreach遍历关联数组
- 6.2.4 list、each函数遍历数组
- 6.2.5 常用操作数组函数
- 6.3 数组的常用函数
- 07. PHP中的正则达达式
- 7.1 正则表达示的定界符
- 7.2 正则表达示中的原子
- 7.3 正则表示中的元字符
- 7.4 正则达达示中的模式修正符
- 7.5 写正则的诀窍和常用正则
- 7.6 用正则写一个UBB文本编辑器
- 08.文件系统
- 8.1 读取文件
- 8.2 创建和修改文件内容
- 8.3 创建临时文件
- 8.4 移动、拷贝和删除文件
- 8.5 检测文件属性函数
- 8.6 文件常用函数和常量
- 8.7 文件锁处机制
- 8.8 目录处理函数
- 8.9 文件权限设置
- 8.10文件路径函数
- 8.11 小小文件留言本
- 8.12 修改配置文件的实例
- 09.PHP文件上传
- 9.1 文件上传需要注意php.ini文件
- 9.2 文件上传的步骤
- 9.3 文件上传表单注意事项
- 9.4 按照数组和步骤完成文件上传
- 9.5 多文件上传
- 9.6 文件上传进度处理
- 10.PHP图像处理
- 10.1 学习前的准备工作
- 10.2 用图片处理函数画一张图
- 10.3 生成验证码
- 10.4 图像缩放和裁剪技术
- 10.5 图片水印处理
- 11.错误处理
- 11.1 禁止显示错误
- 11.2 错误报告级别
- 11.3 错误记录日志
- 11.4 自定义错误处理函数
- 12.MySQL 入门
- 12.1 请进入《MySQL入门》
- 13. PHP操作mysql数据库
- 13.1 数据库连接步骤
- 13.2 通过步骤做一个用户注册
- 13.3 通过步骤做一个列表显示
- 13.4 把用户做个分页
- 13.5 批量和指定删除用户
- 13.6 修改用户信息
- 13.7 数据显示乱码终极解决办法
- 14.会话管理和控制
- 14.1 Cookie概述
- 14.2PHP中的Cookie
- 14.3 session概述
- 14.4 PHP中使用session
- 14.5 SESSION应用实例
- 15.通过cURL来做小偷程序
- 15.1 curl的使用步骤
- 15.2 自定义get方法抓取网页
- 15.3 使用post发送数据
- 16. 用PHP写一个论坛
- 16.1 web2.0始于论坛
- 16.2 需求:开发前你要知道他的样子
- 16.3 核心业务流程
- 16.3.1 用户注册流程
- 16.3.2 普通用户和管理员登陆流程
- 16.3.3 发贴流程
- 16.3.4 回复流程
- 16.3.5 版块管理流程
- 16.3.6 版主业务流程
- 16.3.7 金币奖励和消耗流程
- 16.4 数据库表设计
- 16.5 文件和代码规范
- 16.6 核心功能说明
- 16.6.1 项目目录结构说明
- 16.6.2 公共文件的使用
- 16.6.3 模板引擎讲解
- 16.6.4 用户注册、登陆功能讲解
- 16.6.5 发帖功能讲解
- 16.6.6 回帖功能讲解
- 16.6.7 项目安装模块讲解
- 附录1. 版权声明
- 附录2 . 学习PHP常用的英文单词