咱們來系統的瞭解下ThinkPHP框架開發的應用的標準執行流程:php
用戶URL請求
調用應用入口文件(一般是網站的index.php)
載入框架入口文件(ThinkPHP.php)
記錄初始運行時間和內存開銷
系統常量判斷及定義
載入框架引導類(Think\Think)並執行Think::start方法進行應用初始化
設置錯誤處理機制和自動加載機制
調用Think\Storage類進行存儲初始化(由STORAGE_TYPE常量定義存儲類型)
部署模式下若是存在應用編譯緩存文件則直接加載(直接跳轉到步驟22)
讀取應用模式(由APP_MODE常量定義)的定義文件(如下以普通模式爲例說明)
加載當前應用模式定義的核心文件(普通模式是 ThinkPHP/Mode/common.php)
加載慣例配置文件(普通模式是 ThinkPHP/Conf/convention.php)
加載應用配置文件(普通模式是 Application/Common/Conf/config.php)
加載系統別名定義
判斷並讀取應用別名定義文件(普通模式是 Application/Common/Conf/alias.php)
加載系統行爲定義
判斷並讀取應用行爲定義文件(普通模式是 Application/Common/Conf/tags.php)
加載框架底層語言包(普通模式是 ThinkPHP/Lang/zh-cn.php)
若是是部署模式則生成應用編譯緩存文件
加載調試模式系統配置文件(ThinkPHP/Conf/debug.php)
判斷並讀取應用的調試配置文件(默認是 Application/Common/Conf/debug.php)
判斷應用狀態並讀取狀態配置文件(若是APP_STATUS常量定義不爲空的話)
檢測應用目錄結構並自動生成(若是CHECK_APP_DIR配置開啓而且RUNTIME_PATH目錄不存在的狀況下)
調用Think\App類的run方法啓動應用
應用初始化(app_init)標籤位偵聽並執行綁定行爲
判斷並加載動態配置和函數文件
調用Think\Dispatcher::dispatch方法進行URL請求調度
自動識別兼容URL模式和命令行模式下面的$_SERVER['PATH_INFO']參數
檢測域名部署以及完成模塊和控制器的綁定操做(APP_SUB_DOMAIN_DEPLOY參數開啓)
分析URL地址中的PATH_INFO信息
獲取請求的模塊信息
檢測模塊是否存在和容許訪問
判斷並加載模塊配置文件、別名定義、行爲定義及函數文件
判斷並加載模塊的動態配置和函數文件
模塊的URL模式判斷
模塊的路由檢測(URL_ROUTER_ON開啓)
PATH_INFO處理(path_info)標籤位偵聽並執行綁定行爲
URL後綴檢測(URL_DENY_SUFFIX以及URL_HTML_SUFFIX處理)
獲取當前控制器和操做,以及URL其餘參數
URL請求調度完成(url_dispatch)標籤位偵聽並執行綁定行爲
應用開始(app_begin)標籤位偵聽並執行綁定行爲
調用SESSION_OPTIONS配置參數進行Session初始化(若是不是命令行模式)
根據請求執行控制器方法
若是控制器不存在則檢測空控制器是否存在
控制器開始(action_begin)標籤位偵聽並執行綁定行爲
默認調用系統的ReadHtmlCache行爲讀取靜態緩存(HTML_CACHE_ON參數開啓)
判斷並調用控制器的_initialize初始化方法
判斷操做方法是否存在,若是不存在則檢測是否認義空操做方法
判斷前置操做方法是否認義,有的話執行
Action參數綁定檢測,自動匹配操做方法的參數
若是有模版渲染(調用控制器display方法)
視圖開始(view_begin)標籤位偵聽並執行綁定行爲
調用Think\View的fetch方法解析並獲取模版內容
自動識別當前主題以及定位模版文件
視圖解析(view_parse)標籤位偵聽並執行綁定行爲
默認調用內置ParseTemplate行爲解析模版(普通模式下面)
模版引擎解析模版內容後生成模版緩存
模版過濾替換(template_filter)標籤位偵聽並執行綁定行爲
默認調用系統的ContentReplace行爲進行模版替換
輸出內容過濾(view_filter)標籤位偵聽並執行綁定行爲
默認調用系統的WriteHtmlCache行爲寫入靜態緩存(HTML_CACHE_ON參數開啓)
調用Think\View類的render方法輸出渲染內容
視圖結束(view_end)標籤位偵聽並執行綁定行爲
判斷後置操做方法是否認義,有的話執行
控制器結束(action_end)標籤位偵聽並執行綁定行爲
應用結束(app_end)標籤位偵聽並執行綁定行爲
執行系統的ShowPageTrace行爲(SHOW_PAGE_TRACE參數開啓而且不是AJAX請求)
日誌信息存儲寫入
若是你綁定了更多的應用行爲的話,流程可能會更加複雜。緩存
若是是部署模式下面的第二次請求的話,上面的流程中的步驟10~21是能夠省略的。app