[TOC]
* * * * *
## 1 应用启动源代码(/thinkphp/library/think/App的run())
注:App.php其他部分源代码分析见[附:应用启动文件](http://www.kancloud.cn/zmwtp/tp5/119429)
~~~
class App
{
public static function run()
{
self::initModule(COMMON_MODULE, Config::get());
$config = Config::get();
if (!empty($config['root_namespace'])) {
Loader::addNamespace($config['root_namespace']);
}
if (!empty($config['extra_file_list'])) {
foreach ($config['extra_file_list'] as $file) {
$file = strpos($file, '.') ? $file : APP_PATH . $file . EXT;
if (is_file($file)) {
include_once $file;
}
}
}
date_default_timezone_set($config['default_timezone']);
APP_HOOK && Hook::listen('app_init');
if ($config['lang_switch_on']) {
defined('LANG_SET') or define('LANG_SET', Lang::range());
Lang::load(THINK_PATH . 'lang' . DS . LANG_SET . EXT);
if (!APP_MULTI_MODULE) {
Lang::load(APP_PATH . 'lang' . DS . LANG_SET . EXT);
}
}
if (empty(self::$dispatch['type'])) {
self::route($config);
}
APP_DEBUG && Log::record('[ ROUTE ] ' . var_export(self::$dispatch, true), 'info');
APP_HOOK && Hook::listen('app_begin');
switch (self::$dispatch['type']) {
case 'redirect':
header('Location: ' . self::$dispatch['url'], true, self::$dispatch['status']);
break;
case 'module':
$data = self::module(self::$dispatch['module'], $config);
break;
case 'controller':
$data = Loader::action(self::$dispatch['controller'], self::$dispatch['params']);
break;
case 'method':
$data = self::invokeMethod(self::$dispatch['method'], self::$dispatch['params']);
break;
case 'function':
$data = self::invokeFunction(self::$dispatch['function'], self::$dispatch['params']);
break;
default:
throw new Exception('dispatch type not support', 10008);
}
APP_HOOK && Hook::listen('app_end', $data);
return Response::send($data, Response::type(), Config::get('response_return'));
}
}
~~~
## 2 应用启动App::run()源代码分析
### 1 应用初始化
~~~
self::initModule(COMMON_MODULE,Config::get())
~~~
>[info] 应用的模块初始化
具体的实现见框架流程的[附:应用启动文件](http://www.kancloud.cn/zmwtp/tp5/119429)
~~~
$config = Config::get()
~~~
>[info] 全局配置参数获取
**下面根据配置参数注册根命名空间,加载额外配置文件,设置系统时区**
具体实现见框架流程的[附:全局配置文件](http://www.kancloud.cn/zmwtp/tp5/119434)
~~~
if (!empty($config['root_namespace'])) {
Loader::addNamespace($config['root_namespace']);
}
~~~
>[info] 注册根命名空间
具体实现见框架流程的[附:自动加载器](http://www.kancloud.cn/zmwtp/tp5/119431)
~~~
if (!empty($config['extra_file_list'])) {
foreach ($config['extra_file_list'] as $file) {
$file = strpos($file, '.') ? $file : APP_PATH . $file . EXT;
if (is_file($file)) {
include_once $file;
}
}
}
~~~
>[info] 加载配置的额外文件
~~~
date_default_timezone_set($config['default_timezone']);
~~~
>[info] 设置系统时区
系统时区见基础原理的[php系统时区](http://www.kancloud.cn/zmwtp/tp5/119448)
~~~
APP_HOOK && Hook::listen('app_init');
~~~
>[info] 应用初始化回调处理
监听回调见框架流程的[附:监听回调注册文件](http://www.kancloud.cn/zmwtp/tp5/119435)
### 2 Url路由解析,并设置调度类型
~~~
if (empty(self::$dispatch['type'])) {
self::route($config);
}
~~~
>[info] 解析url
调用self::route(),解析url,生成$dispatch。
路由分析见框架流程的[附:全局路由文件](http://www.kancloud.cn/zmwtp/tp5/119438)
~~~
APP_DEBUG && Log::record('[ ROUTE ] ' . var_export(self::$dispatch, true), 'info');
~~~
>[info] 日志记录路由分析信息
日志记录的实现见框架流程的[附:日志记录文件](http://www.kancloud.cn/zmwtp/tp5/119437)
~~~
APP_HOOK && Hook::listen('app_begin');
~~~
>[info] 同上 应用启动回调处理
* * * * *
### 3 应用调度
~~~
switch (self::$dispatch['type']) {
case 'redirect':
header('Location: ' . self::$dispatch['url'], true, self::$dispatch['status']);
break;
case 'module':
$data = self::module(self::$dispatch['module'], $config);
break;
case 'controller':
$data = Loader::action(self::$dispatch['controller'], self::$dispatch['params']);
break;
case 'method':
$data = self::invokeMethod(self::$dispatch['method'], self::$dispatch['params']);
break;
case 'function':
$data = self::invokeFunction(self::$dispatch['function'], self::$dispatch['params']);
break;
default:
throw new Exception('dispatch type not support', 10008);
}
~~~
根据调度器类型self::$dispatch['type']进行不同的应用的调度。
将应用业务执行的结果保存到$data中
**应用的调度是应用启动的核心部分。**
其内容见框架流程的[应用调度分析](http://www.kancloud.cn/zmwtp/tp5/119428)
~~~
APP_HOOK && Hook::listen('app_end', $data);
~~~
同上 应用完成回调处理
### 4 输出数据到客户端
~~~
return Response::send($data, Response::type(), Config::get('response_return'));
~~~
调用Response::send()返回数据到客户端
输出的原理见框架流程的[附:数据输出文件,](http://www.kancloud.cn/zmwtp/tp5/119439)
## 3 总结
应用启动App::run()是框架核心。
首先 根据配置初始化应用的公共模块
然后 根据配置参数依次配注册根命名空间 加载额外文件 设置系统时区,
此时调用监听app_init事件的回调方法
然后 开启多语言机制
接着 对url进行路由分析,获取url可以使用的调度类型
最后 根据调度类型,分别调用应用的对应逻辑业务实现。
**这里的路由分析和应用调度是框架从框架底层到应用跳转的核心部分,**
因此单独拿出[一节](http://www.kancloud.cn/zmwtp/tp5/119428)来进行分析。
路由分析中涉及路由规则的定义,使用方法见使用范例的[路由规则注册](http://www.kancloud.cn/zmwtp/tp5/120040)
调度类型可以灵活定义业务应用的组织方式,使用方法见使用范例的 [多种应用组织](http://www.kancloud.cn/zmwtp/tp5/120210)
- 更新记录
- 概述
- 文件索引
- 函数索引
- 章节格式
- 框架流程
- 前:章节说明
- 主:(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(自动加载)