-
使用者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請求)
-
日志資訊存儲寫入
複制代碼