[TOC]
* * * * *
## 1 框架引导文件源代码
> 独立模式(/thinkphp/start.php)
~~~
namespace think;
require __DIR__ . '/base.php';
require CORE_PATH . 'Loader.php';
if (is_file(ROOT_PATH . 'env' . EXT)) {
$env = include ROOT_PATH . 'env' . EXT;
foreach ($env as $key => $val) {
$name = ENV_PREFIX . $key;
putenv("$name=$val");
}
}
if (!defined('APP_DEBUG')) {
$debug = getenv(ENV_PREFIX . 'APP_DEBUG');
define('APP_DEBUG', $debug);
}
$mode = require MODE_PATH . APP_MODE . EXT;
if (isset($mode['namespace'])) {
Loader::addNamespace($mode['namespace']);
}
Loader::register();
if (isset($mode['alias'])) {
Loader::addMap($mode['alias']);
}
Error::register();
if (isset($mode['config'])) {
is_array($mode['config']) ? Config::set($mode['config']) : Config::load($mode['config']);
}
if (APP_HOOK && isset($mode['tags'])) {
Hook::import($mode['tags']);
}
if (APP_AUTO_RUN) {
App::run();
}
~~~
> composer包模式(\vendor\topthink\framework\start.php)
~~~
defined('THINK_AUTOLOAD') or define('THINK_AUTOLOAD', getenv('THINK_AUTOLOAD') !== '0');
if (THINK_AUTOLOAD) {
require_once __DIR__ . '/think.php';
}
~~~
> (\vendor\topthink\framework\think.php)
~~~
namespace think;
require __DIR__ . '/base.php';
require CORE_PATH . 'Loader.php';
if (is_file(ROOT_PATH . 'env' . EXT)) {
$env = include ROOT_PATH . 'env' . EXT;
foreach ($env as $key => $val) {
$name = ENV_PREFIX . $key;
putenv("$name=$val");
}
}
if (!defined('APP_DEBUG')) {
$debug = getenv(ENV_PREFIX . 'APP_DEBUG');
define('APP_DEBUG', $debug);
}
$mode = require MODE_PATH . APP_MODE . EXT;
if (isset($mode['namespace'])) {
Loader::addNamespace($mode['namespace']);
}
Loader::register();
if (isset($mode['alias'])) {
Loader::addMap($mode['alias']);
}
Error::register();
if (isset($mode['config'])) {
is_array($mode['config']) ? Config::set($mode['config']) : Config::load($mode['config']);
}
if (APP_HOOK && isset($mode['tags'])) {
Hook::import($mode['tags']);
}
if (APP_AUTO_RUN) {
App::run();
}
~~~
## 2 源代码分析
> composer包模式(\vendor\topthink\framework\start.php)
`defined('THINK_AUTOLOAD') or define('THINK_AUTOLOAD', getenv('THINK_AUTOLOAD') !== '0');`
检查加载器模式
~~~
if (THINK_AUTOLOAD) {
require_once __DIR__ . '/think.php';
}
~~~
加载composer包的框架引导文件
* * * * *
> 独立模式(\start.php)与composer包模式公共部分(\vendor\topthink\framework\think.php)
~~~
namespace think;
~~~
使用think命名空间
命名空间的原理见基础原理的[php命名空间](http://www.kancloud.cn/zmwtp/tp5/119446)。
~~~
require __DIR__.'base.php';
~~~
### 1 加载框架全局变量文件
具体内容见框架流程的[附:全局变量文件](http://www.kancloud.cn/zmwtp/tp5/119430)
~~~
require CORE_PATH.'Loader.php';
~~~
### 2 加载框架加载器
加载器文件的分析见框架流程的[附:自动加载器](http://www.kancloud.cn/zmwtp/tp5/119431)
加载器的原理见基础原理的[php的自动加载](http://www.kancloud.cn/zmwtp/tp5/119447)
~~~
$mode = require MODE_PATH.APP_MODE.EXT;
~~~
### 3 加载框架的模式配置文件
模式配置文件的分析见框架流程的[附:模式配置文件](http://www.kancloud.cn/zmwtp/tp5/119432)
模式配置文件的操作见使用范例的[运行模式开发](http://www.kancloud.cn/zmwtp/tp5/120208)
`Loader::register();`
### 4 注册自动加载器
~~~
if (isset($mode['alias'])) {
Loader::addMap($mode['alias']);
}
~~~
### 5 加载框架的模式别名文件
~~~
Error::register()
~~~
### 6 注册错误和异常处理
错误和异常机制见框架流程的[附:错误和异常处理文件](http://www.kancloud.cn/zmwtp/tp5/119433)
~~~
if (isset($mode['config'])) {
is_array($mode['config']) ? Config::set($mode['config']) : Config::load($mode['config']);
}
~~~
### 7 加载模式默认全局配置文件
全局配置操作见框架流程的[附:全局配置文件](http://www.kancloud.cn/zmwtp/tp5/119434)
~~~
if (APP_HOOK && isset($mode['tags'])) {
Hook::import(is_array($mode['tags']) ? $mode['tags'] : include $mode['tags']);
}
~~~
### 8 注册模式监听回调标签
监听文件内容见框架流程的行为[附:监听回调注册文件](http://www.kancloud.cn/zmwtp/tp5/119435)
~~~
if (APP_AUTO_RUN) {
App::run();
}
~~~
### 9 检测是否启动应用
跳转到应用启动App::run()运行。
## 3 总结
框架启动中,根据入口文件public/index.php或者全局变量文件base.php中的**APP_MODE** 加载thinkphp/mode/下面对应的**模式配置文件**
然后根据模式配置文件(默认使用thinkphp/mode/common.php)的配置初**始化模式环境**
依次为**注册命名空间**,**注册类别名**,**加载模式配置文件**(默认为thinkphp/convention.php),**注册模式监听回调**
然后根据全局变量APP_AUTO_BUILD**自动创建应用目录**
最后**启动应用**App::run()。
框架启动文件,通常情况下不需要修改,其中涉及到的模式文件与运行模式开发有关,其使用思路见使用范例的[运行模式开发](http://www.kancloud.cn/zmwtp/tp5/120208)
- 更新记录
- 概述
- 文件索引
- 函数索引
- 章节格式
- 框架流程
- 前:章节说明
- 主:(index.php)入口
- 主:(start.php)框架引导
- 主:(App.php)应用启动
- 主:(App.php)应用调度
- C:(Controller.php)应用控制器
- M:(Model.php)数据模型
- V:(View.php)视图对象
- 附:(App.php)应用启动
- 附:(base.php)全局变量
- 附:(common.php)模式配置
- 附:(convention.php)全局配置
- 附:(Loader.php)自动加载器
- 附:(Build.php)自动生成
- 附:(Hook.php)监听回调
- 附:(Route.php)全局路由
- 附:(Response.php)数据输出
- 附:(Log.php)日志记录
- 附:(Exception.php)异常处理
- 框架工具
- 另:(helper.php)辅助函数
- 另:(Cache.php)数据缓存
- 另:(Cookie.php)cookie操作
- 另:(Console.php)控制台
- 另:(Debug.php)开发调试
- 另:(Error.php)错误处理
- 另:(Url.php)Url操作文件
- 另:(Loader.php)加载器实例化
- 另:(Input.php)数据输入
- 另:(Lang.php)语言包管理
- 另:(ORM.php)ORM基类
- 另:(Process.php)进程管理
- 另:(Session.php)session操作
- 另:(Template.php)模板解析
- 框架驱动
- D:(\config)配置解析
- D:(\controller)控制器扩展
- D:(\model)模型扩展
- D:(\db)数据库驱动
- D:(\view)模板解析
- D:(\template)模板标签库
- D:(\session)session驱动
- D:(\cache)缓存驱动
- D:(\console)控制台
- D:(\process)进程扩展
- T:(\traits)Trait目录
- D:(\exception)异常实现
- D:(\log)日志驱动
- 使用范例
- 服务器与框架的安装
- 控制器操作
- 数据模型操作
- 视图渲染控制
- MVC开发初探
- 模块开发
- 入口文件定义全局变量
- 运行模式开发
- 框架配置
- 自动生成应用
- 事件与插件注册
- 路由规则注册
- 输出控制
- 多种应用组织
- 综合应用
- tp框架整合后台auto架构快速开发
- 基础原理
- php默认全局变量
- php的魔术方法
- php命名空间
- php的自动加载
- php的composer
- php的反射
- php的trait机制
- php设计模式
- php的系统时区
- php的异常错误
- php的输出控制
- php的正则表达式
- php的闭包函数
- php的会话控制
- php的接口
- php的PDO
- php的字符串操作
- php的curl
- 框架心得
- 心:整体结构
- 心:配置详解
- 心:加载器详解
- 心:输入输出详解
- 心:url路由详解
- 心:模板详解
- 心:模型详解
- 心:日志详解
- 心:缓存详解
- 心:控制台详解
- 框架更新
- 4.20(验证类,助手函数)
- 4.27(新模型Model功能)
- 5.4(新数据库驱动)
- 7.28(自动加载)