yun 发表于 2017-5-6 00:39:47

关于thinkphp安装引导详解

thinkphp安装引导程序

我们的程序为什么需要有个安装引导?
1 . 有安装引导;就不需要我们再长篇大论的讲解怎么导入sql文件;怎么更改配置项了;
2 . 可以写一些版权或者使用说明;
3 . 可以先对环境做一些检测;

这里为thinkphp纯手工量身打造了一个简单的安装引导流程;
当然;更重要的是;这个安装是可以独立于thinkphp的;
如果想在别的项目中使用;也可以非常方便的移植;
把目录拷走;加几行代码就完事了;

一:导入安装引导程序
/Public/install/
把install放到自己项目的目录下;
里面重要的是bjyadmin.sql 这个是数据库文件;
并且初始状态下;是没有install.lock文件的;

二:检测是否安装/index.php
// 检测是否是新安装
if(file_exists("./Public/install") && !file_exists("./Public/install/install.lock")){
    // 组装安装url
    $url=$_SERVER['HTTP_HOST'].trim($_SERVER['SCRIPT_NAME'],'index.php').'Public/install/index.php';
    // 使用http://域名方式访问;避免./Public/install 路径方式的兼容性和其他出错问题
    header("Location:http://$url");
    die;
}在入口文件中;增加了这样一段检测是否安装的代码;

三:流程
首先;当访问index.php的时候;
会先走上面那段代码;判断/Public/install/install.lock文件是否存在;
如果不存在;那么表示还没安装;
则会重定向到/Public/install/index.php走安装程序;
当按照要求输入数据库的账号密码安装成功后;
会创建一个/Public/install/install.lock文件;
再访问入口文件的时候;就会跳过重定向;
同时会把输入的数据库账号密码写入到 /Application/Common/Conf/db.php文件中;

为什么要单独建一个db.php文件的原因;

/Public/install/index.php文件中写着安装过程;
但我并不打算在本文中铺开介绍,因为……我懒得写;
里面已经给了详细的注释了;直接看源代码即可;
页: [1]
查看完整版本: 关于thinkphp安装引导详解