[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.hmoore.net/zmwtp/tp5/119446)。
~~~
require __DIR__.'base.php';
~~~
### 1 加載框架全局變量文件
具體內容見框架流程的[附:全局變量文件](http://www.hmoore.net/zmwtp/tp5/119430)
~~~
require CORE_PATH.'Loader.php';
~~~
### 2 加載框架加載器
加載器文件的分析見框架流程的[附:自動加載器](http://www.hmoore.net/zmwtp/tp5/119431)
加載器的原理見基礎原理的[php的自動加載](http://www.hmoore.net/zmwtp/tp5/119447)
~~~
$mode = require MODE_PATH.APP_MODE.EXT;
~~~
### 3 加載框架的模式配置文件
模式配置文件的分析見框架流程的[附:模式配置文件](http://www.hmoore.net/zmwtp/tp5/119432)
模式配置文件的操作見使用范例的[運行模式開發](http://www.hmoore.net/zmwtp/tp5/120208)
`Loader::register();`
### 4 注冊自動加載器
~~~
if (isset($mode['alias'])) {
Loader::addMap($mode['alias']);
}
~~~
### 5 加載框架的模式別名文件
~~~
Error::register()
~~~
### 6 注冊錯誤和異常處理
錯誤和異常機制見框架流程的[附:錯誤和異常處理文件](http://www.hmoore.net/zmwtp/tp5/119433)
~~~
if (isset($mode['config'])) {
is_array($mode['config']) ? Config::set($mode['config']) : Config::load($mode['config']);
}
~~~
### 7 加載模式默認全局配置文件
全局配置操作見框架流程的[附:全局配置文件](http://www.hmoore.net/zmwtp/tp5/119434)
~~~
if (APP_HOOK && isset($mode['tags'])) {
Hook::import(is_array($mode['tags']) ? $mode['tags'] : include $mode['tags']);
}
~~~
### 8 注冊模式監聽回調標簽
監聽文件內容見框架流程的行為[附:監聽回調注冊文件](http://www.hmoore.net/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.hmoore.net/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(自動加載)