再次学习TP
用户URL请求
调用应用入口文件
载入框架入口文件*******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
这是第22步
判断应用状态并且读取状态配置文件*******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_ROUTE_ON开启
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行为
日志信息存储写入