ThinkPHP 3.2.3 框架開發的應用的標準執行流程如下:
1. 用戶URL請求
2. 調用**應用入口文件**(通常是網站的index.php)
3. 載入**框架入口文件**(ThinkPHP.php)
4. **記錄**初始運行時間和內存開銷
5. **系統常量**判斷及定義
6. 載入框架引導類(Think\Think)并執行**Think::start方法**進行**應用初始化**
7. 設置**錯誤處理機制和自動加載機制**
8. 調用Think\Storage類進行**存儲初始化**(由STORAGE_TYPE常量定義存儲類型)
9. 部署模式下如果存在應用編譯緩存文件則直接加載(直接跳轉到步驟22)
10. **讀取應用模式**(由APP_MODE常量定義)的定義文件(以下以普通模式為例說明)
11. **加載當前應用模式**定義的核心文件(普通模式是 ThinkPHP/Mode/common.php)
12. **加載慣例配置**文件(普通模式是 ThinkPHP/Conf/convention.php)
13. **加載應用配置**文件(普通模式是 Application/Common/Conf/config.php)
14. **加載系統別名**定義
15. 判斷并讀取應用別名定義文件(普通模式是 Application/Common/Conf/alias.php)
16. **加載系統行為**定義
17. 判斷并讀取應用行為定義文件(普通模式是 Application/Common/Conf/tags.php)
18. **加載框架底層語言**包(普通模式是 ThinkPHP/Lang/zh-cn.php)
19. 如果是部署模式則生成應用編譯緩存文件
20. 加載調試模式系統配置文件(ThinkPHP/Conf/debug.php)
21. 判斷并讀取應用的調試配置文件(默認是 Application/Common/Conf/debug.php)
22. **判斷應用狀態并讀取狀態配置文件**(如果APP_STATUS常量定義不為空的話)
23. 檢測應用目錄結構并自動生成(如果CHECK_APP_DIR配置開啟并且RUNTIME_PATH目錄不存在的情況下)
24. **調用Think\App類的run方法啟動應用**
25. 應用初始化**(app_init)**標簽位偵聽并執行綁定行為
26. 判斷并加載動態配置和函數文件
27. 調用**Think\Dispatcher::dispatch**方法進行URL請求調度
28. 自動識別兼容URL模式和命令行模式下面的**$_SERVER['PATH_INFO']**參數
29. 檢測域名部署以及完成模塊和控制器的綁定操作(APP_SUB_DOMAIN_DEPLOY參數開啟)
30. 分析URL地址中的PATH_INFO信息
31. **獲取請求的模塊信息**
32. **檢測模塊是否存在和允許訪問**
33. 判斷并加載模塊配置文件、別名定義、行為定義及函數文件
34. 判斷并加載模塊的動態配置和函數文件
35. 模塊的URL模式判斷
36. 模塊的路由檢測(**URL_ROUTER_ON開啟**)
37. PATH_INFO處理(path_info)標簽位偵聽并執行綁定行為
38. URL后綴檢測(**URL_DENY_SUFFIX**以及URL_HTML_SUFFIX處理)
39. 獲取當前控制器和操作,以及URL其他參數
40. URL請求調度完成(**url_dispatch**)標簽位偵聽并執行綁定行為
41. 應用開始(**app_begin**)標簽位偵聽并執行綁定行為
42. 調用SESSION_OPTIONS配置參數進行Session初始化(如果不是命令行模式)
43. 根據請求執行控制器方法
44. 如果控制器不存在則檢測空控制器是否存在
45. 控制器開始(**action_begin**)標簽位偵聽并執行綁定行為
46. 默認調用系統的ReadHtmlCache行為讀取靜態緩存(HTML_CACHE_ON參數開啟)
47. 判斷并調用控制器的**_initialize**初始化方法
48. 判斷操作方法是否存在,如果不存在則檢測是否定義空操作方法
49. 判斷前置操作方法是否定義,有的話執行
50. Action參數綁定檢測,自動匹配操作方法的參數
51. 如果有模版渲染(調用控制器display方法)
52. 視圖開始(**view_begin**)標簽位偵聽并執行綁定行為
53. 調用Think\View的fetch方法解析并獲取模版內容
54. 自動識別當前主題以及定位模版文件
55. 視圖解析(**view_parse**)標簽位偵聽并執行綁定行為
56. 默認調用內置ParseTemplate行為解析模版(普通模式下面)
57. 模版引擎解析模版內容后生成模版緩存
58. 模版過濾替換(**template_filter**)標簽位偵聽并執行綁定行為
59. 默認調用系統的ContentReplace行為進行模版替換
60. 輸出內容過濾(**view_filter**)標簽位偵聽并執行綁定行為
61. 默認調用系統的WriteHtmlCache行為寫入靜態緩存(HTML_CACHE_ON參數開啟)
62. 調用Think\View類的render方法輸出渲染內容
63. 視圖結束(**view_end**)標簽位偵聽并執行綁定行為
64. 判斷后置操作方法是否定義,有的話執行
65. 控制器結束(**action_end**)標簽位偵聽并執行綁定行為
66. 應用結束(**app_end**)標簽位偵聽并執行綁定行為
67. 執行系統的ShowPageTrace行為(SHOW_PAGE_TRACE參數開啟并且不是AJAX請求)
68. 日志信息存儲寫入
> 如果是部署模式下面的第二次請求的話,上面的流程中的步驟10~21是可以省略的。