我們來系統的瞭解下ThinkPHP框架開發的應用的標準執行流程:
使用者URL請求
呼叫應用入口檔案(通常是網站的index.php)
載入框架入口檔案(ThinkPHP.php)
記錄初始執行時間和記憶體開銷
系統常量判斷及定義
載入框架引導類(ThinkThink)並執行Think::start方法進行應用初始化
設定錯誤處理機制和自動載入機制
呼叫ThinkStorage類進行儲存初始化(由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目錄不存在的情況下)
呼叫ThinkApp類的run方法啟動應用
應用初始化(app_init)標籤位偵聽並執行繫結行為
判斷並載入動態配置和函式檔案
呼叫ThinkDispatcher::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)標籤位偵聽並執行繫結行為
呼叫ThinkView的fetch方法解析並獲取模版內容
自動識別當前主題以及定位模版檔案
檢視解析(view_parse)標籤位偵聽並執行繫結行為
預設呼叫內建ParseTemplate行為解析模版(普通模式下面)
模版引擎解析模版內容後生成模版快取
模版過濾替換(template_filter)標籤位偵聽並執行繫結行為
預設呼叫系統的ContentReplace行為進行模版替換
輸出內容過濾(view_filter)標籤位偵聽並執行繫結行為
預設呼叫系統的WriteHtmlCache行為寫入靜態快取(HTML_CACHE_ON引數開啟)
呼叫ThinkView類的render方法輸出渲染內容
檢視結束(view_end)標籤位偵聽並執行繫結行為
判斷後置操作方法是否定義,有的話執行
控制器結束(action_end)標籤位偵聽並執行繫結行為
應用結束(app_end)標籤位偵聽並執行繫結行為
執行系統的ShowPageTrace行為(SHOW_PAGE_TRACE引數開啟並且不是AJAX請求)
日誌資訊儲存寫入
如果你繫結了更多的應用行為的話,流程可能會更加複雜。
如果是部署模式下面的第二次請求的話,上面的流程中的步驟10~21是可以省略的。