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是可以省略的。