ThinkPHP-3.2.*系统流程,完全开放编辑,支持复制
2017-07-12 10:03:19 0 举报
ThinkPHP3.2.*系统流程,大家可以一起细化所有流程,方便深入学习此框架
作者其他创作
大纲/内容
49.判断前置操作方法是否定义,有的话执行
App::init();
26.判断并加载动态配置和函数文件
2.调用应用入口文件(通常是网站的index.php)
4.记录初始运行时间和内存开销
14.加载系统别名定义
35.模块的URL模式判断
// 应用开始标签Hook::listen('app_begin');
43.根据请求执行控制器方法
37.PATH_INFO处理(path_info)标签位侦听并执行绑定行为
27.调用Think\\Dispatcher::dispatch方法进行URL请求调度
3.载入框架入口文件(ThinkPHP.php)
32.检测模块是否存在和允许访问
33.判断并加载模块配置文件、别名定义、行为定义及函数文件
// 应用初始化标签 Hook::listen('app_init');
51.如果有模版渲染(调用控制器display方法)
16.加载系统行为定义
Y
N
68.日志信息存储写入(ThinkPHP结束)
21.判断并读取应用的调试配置文件(默认是 Application/Common/Conf/debug.php)
53.调用Think\\View的fetch方法解析并获取模版内容
54.自动识别当前主题以及定位模版文件
50.Action参数绑定检测,自动匹配操作方法的参数
App::exec();
45.控制器开始(action_begin)标签位侦听并执行绑定行为
61.默认调用系统的WriteHtmlCache行为写入静态缓存(HTML_CACHE_ON参数开启)
29.检测域名部署以及完成模块和控制器的绑定操作(APP_SUB_DOMAIN_DEPLOY参数开启)
13.加载应用配置文件(普通模式是 Application/Common/Conf/config.php)
36.模块的路由检测(URL_ROUTER_ON开启)
39.获取当前控制器和操作,以及URL其他参数
6.载入框架引导类(Think\\Think)并执行Think::start方法进行应用初始化
19.如果是部署模式则生成应用编译缓存文件
// 运行应用 App::run();
类与对象的调用
7.设置错误处理机制 和 自动加载机制
// 设置系统时区 date_default_timezone_set(C('DEFAULT_TIMEZONE'));
11.加载当前应用模式定义的核心文件(普通模式是 ThinkPHP/Mode/common.php)
8.调用Think\\Storage类进行存储初始化(由STORAGE_TYPE常量定义存储类型)
63.视图结束(view_end)标签位侦听并执行绑定行为
57.模版引擎解析模版内容后生成模版缓存
65.控制器结束(action_end)标签位侦听并执行绑定行为
25.应用初始化(app_init)标签位侦听并执行绑定行为
9.部署模式下如果存在应用编译缓存文件
调用应用入口文件(通常是网站的index.php)
// 加载核心Think类require CORE_PATH.'Think'.EXT;Think\\Think::start();
41.应用开始(app_begin)标签位侦听并执行绑定行为
进一步设置一些初始化常量
56.默认调用内置ParseTemplate行为解析模版(普通模式下面)
...
67.执行系统的ShowPageTrace行为(SHOW_PAGE_TRACE参数开启并且不是AJAX请求)
55.视图解析(view_parse)标签位侦听并执行绑定行为
设置一些初始化常量
66.应用结束(app_end)标签位侦听并执行绑定行为
require './ThinkPHP/ThinkPHP.php';
47.判断并调用控制器的_initialize初始化方法
20.加载调试模式系统配置文件(ThinkPHP/Conf/debug.php)
Think\\Think::start();
18.加载框架底层语言包(普通模式是 ThinkPHP/Lang/zh-cn.php)
// 应用结束标签Hook::listen('app_end');
10.读取应用模式(由APP_MODE常量定义)的定义文件(以下以普通模式为例说明)
// URL调度Dispatcher::dispatch();
// 初始化文件存储方式 Storage::connect(STORAGE_TYPE);
// 记录加载文件时间G('loadTime');
31.获取请求的模块信息
ThinkPHP-3.2.*系统流程
58.模版过滤替换(template_filter)标签位侦听并执行绑定行为
23.检测应用目录结构并自动生成(如果CHECK_APP_DIR配置开启并且RUNTIME_PATH目录不存在的情况下)
App::run();
加载或编译各种核心库、配置如:注册AUTOLOAD方法-自动加载机制
34.判断并加载模块的动态配置和函数文件
主线
(以下以普通模式为例说明)
24.调用Think\\App类的run方法启动应用
如果你绑定了更多的应用行为的话,流程可能会更加复杂。
42.调用SESSION_OPTIONS配置参数进行Session初始化(如果不是命令行模式)
52.视图开始(view_begin)标签位侦听并执行绑定行为
60.输出内容过滤(view_filter)标签位侦听并执行绑定行为
64.判断后置操作方法是否定义,有的话执行
28.自动识别兼容URL模式和命令行模式下面的$_SERVER['PATH_INFO']参数
生成应用编译缓存文件
Build::checkDir($module);
12.加载惯例配置文件(普通模式是 ThinkPHP/Conf/convention.php)
40.URL请求调度完成(url_dispatch)标签位侦听并执行绑定行为
59.默认调用系统的ContentReplace行为进行模版替换
1.用户URL请求
62.调用Think\\View类的render方法输出渲染内容
// URL调度结束标签Hook::listen('url_dispatch');
15.判断并读取应用别名定义文件(普通模式是 Application/Common/Conf/alias.php)
5.系统常量判断及定义
应用模式提供了对核心框架进行改造的机会,可以让你的应用适应更多的环境和不同的要求。每个应用模式有自己的模式定义文件,用于配置当前模式需要加载的核心文件和配置文件,以及别名定义、行为扩展定义等等。根据模式定义文件的定义位置和入口是否需要定义模式,可以分为显式应用模式和隐含应用模式。详情看手册--应用模式
38.URL后缀检测(URL_DENY_SUFFIX以及URL_HTML_SUFFIX处理)
22.判断应用状态并读取状态配置文件(如果APP_STATUS常量定义不为空的话)
17.判断并读取应用行为定义文件(普通模式是 Application/Common/Conf/tags.php)
30.分析URL地址中的PATH_INFO信息
46.默认调用系统的ReadHtmlCache行为读取静态缓存(HTML_CACHE_ON参数开启)
48.判断操作方法是否存在,如果不存在则检测是否定义空操作方法
44.如果控制器不存在则检测空控制器是否存在
Dispatcher::dispatch();
收藏
0 条评论
下一页