总体来说,应用的流程涉及到几个文件:
Index.php
ThinkPHP.php
Think.class.php
App.class.php
Dispatcher.class.php
ThinkPHP/Mode/common.php
ReadHtmlBehavior.class.php
Route.class.php
Hook.class.php
ContentReplaceBehavior.class.php
WriteHtmlCacheBehavior.class.php

ThinkPHP框架开发的应用的标准执行流程如下:
1. 用户URL请求
2. 调用应用入口文件(通常是网站的index.php)
3. 载入框架入口文件(ThinkPHP.php)
4. 记录初始运行时间和内存开销

  1. (引用自ThinkPHP.php)
  2. // 记录开始运行时间
  3. $GLOBALS['_beginTime'] = microtime(TRUE);
  4. // 记录内存初始使用
  5. define('MEMORY_LIMIT_ON',function_exists('memory_get_usage'));
  6. if(MEMORY_LIMIT_ON) $GLOBALS['_startUseMems'] = memory_get_usage();

5. 系统常量判断及定义

  1. (引用自ThinkPHP.php)
  2. // 系统常量定义
  3. defined('THINK_PATH') or define('THINK_PATH', __DIR__.'/');
  4. defined('APP_PATH') or define('APP_PATH', dirname($_SERVER['SCRIPT_FILENAME']).'/');
  5. defined('APP_STATUS') or define('APP_STATUS', ''); // 应用状态 加载对应的配置文件
  6. defined('APP_DEBUG') or define('APP_DEBUG', false); // 是否调试模式

6. 载入框架引导类(Think\Think)并执行Think::start方法进行应用初始化

  1. (引用自ThinkPHP.php)
  2. // 应用初始化
  3. Think\Think::start();

7. 设置错误处理机制和自动加载机制

  1. (引用Think.class.php)
  2. // 注册AUTOLOAD方法
  3. spl_autoload_register('Think\Think::autoload');
  4. // 设定错误和异常处理
  5. register_shutdown_function('Think\Think::fatalError');
  6. set_error_handler('Think\Think::appError');
  7. set_exception_handler('Think\Think::appException');

8. 调用Think\Storage类进行存储初始化(由STORAGE_TYPE常量定义存储类型)

  1. (引用Think.class.php)
  2. // 初始化文件存储方式
  3. Storage::connect(STORAGE_TYPE);

9. 部署模式下如果存在应用编译缓存文件则直接加载(直接跳转到步骤22)

  1. (引用Think.class.php)
  2. if(!APP_DEBUG && Storage::has($runtimefile)){
  3. Storage::load($runtimefile);
  4. }

10. 读取应用模式(由APP_MODE常量定义)的定义文件(以下以普通模式为例说明)
Thinkphp框架默认的应用模式 为普通模式。

    1. (引用Think.class.php)
    2.  
    3. // 读取应用模式
    4. $mode = include is_file(CONF_PATH.'core.php')?CONF_PATH.'core.php':MODE_PATH.APP_MODE.'.php';

11. 加载当前应用模式定义的核心文件(普通模式是 ThinkPHP/Mode/common.php)

    1. (common.php)
    2. THINK_PATH.'Conf/convention.php', // 系统惯例配置
    3. CONF_PATH.'config'.CONF_EXT, // 应用公共配置

12. 加载惯例配置文件(普通模式是 ThinkPHP/Conf/convention.php)

13. 加载应用配置文件(普通模式是 Application/Common/Conf/config.php)

14. 加载系统别名定义

    1. (common.php)
    2. // 别名定义
    3. 'alias' => array(
    4. 'Think\Log' => CORE_PATH . 'Log'.EXT,
    5. 'Think\Log\Driver\File' => CORE_PATH . 'Log/Driver/File'.EXT,
    6. 'Think\Exception' => CORE_PATH . 'Exception'.EXT,
    7. 'Think\Model' => CORE_PATH . 'Model'.EXT,
    8. 'Think\Db' => CORE_PATH . 'Db'.EXT,
    9. 'Think\Template' => CORE_PATH . 'Template'.EXT,
    10. 'Think\Cache' => CORE_PATH . 'Cache'.EXT,
    11. 'Think\Cache\Driver\File' => CORE_PATH . 'Cache/Driver/File'.EXT,
    12. 'Think\Storage' => CORE_PATH . 'Storage'.EXT,
    13. ),

15. 判断并读取应用别名定义文件(普通模式是 Application/Common/Conf/alias.php)
16. 加载系统行为定义
17. 判断并读取应用行为定义文件(普通模式是 Application/Common/Conf/tags.php)

    1. (tags.php)
    2. 'app_init'=>array('Common\Behavior\InitHookBehavior')

18. 加载框架底层语言包(普通模式是 ThinkPHP/Lang/zh-cn.php)
19. 如果是部署模式则生成应用编译缓存文件
20. 加载调试模式系统配置文件(ThinkPHP/Conf/debug.php)
21. 判断并读取应用的调试配置文件(默认是 Application/Common/Conf/debug.php)
22. 判断应用状态并读取状态配置文件(如果APP_STATUS常量定义不为空的话)

    1. think.class.php
    2. // 读取当前应用状态对应的配置文件
    3. if(APP_STATUS && is_file(CONF_PATH.APP_STATUS.CONF_EXT))
    4. C(include CONF_PATH.APP_STATUS.CONF_EXT);

23. 检测应用目录结构并自动生成(如果CHECK_APP_DIR配置开启并且RUNTIME_PATH目录不存在的情况下)

    1. think.class.php
    2. // 检查应用目录结构 如果不存在则自动创建
    3. if(C('CHECK_APP_DIR')) {
    4. $module = defined('BIND_MODULE') ? BIND_MODULE : C('DEFAULT_MODULE');
    5. if(!is_dir(APP_PATH.$module) || !is_dir(LOG_PATH)){
    6. // 检测应用目录结构
    7. Build::checkDir($module);
    8. }
    9. }

24. 调用Think\App类的run方法启动应用

    1. think.class.php
    2. // 运行应用
    3. App::run();

25. 应用初始化(app_init)标签位侦听并执行绑定行为
26. 判断并加载动态配置和函数文件
27. 调用Think\Dispatcher::dispatch方法进行URL请求调度

    1. App.class.php
    2. Dispatcher::dispatch();

28. 自动识别兼容URL模式和命令行模式下面的$_SERVER['PATH_INFO']参数

    1. Dispatcher.class.php
    2. $_SERVER['PATH_INFO'] = $_GET[$varPath];

29. 检测域名部署以及完成模块和控制器的绑定操作(APP_SUB_DOMAIN_DEPLOY参数开启)

    1. Dispatcher.class.php

30. 分析URL地址中的PATH_INFO信息

    1. Dispatcher.class.php

31. 获取请求的模块信息
32. 检测模块是否存在和允许访问
33. 判断并加载模块配置文件、别名定义、行为定义及函数文件
34. 判断并加载模块的动态配置和函数文件
35. 模块的URL模式判断
36. 模块的路由检测(URL_ROUTER_ON开启)

    1. Dispatcher.class.php

37. PATH_INFO处理(path_info)标签位侦听并执行绑定行为
38. URL后缀检测(URL_DENY_SUFFIX以及URL_HTML_SUFFIX处理)
39. 获取当前控制器和操作,以及URL其他参数
40. URL请求调度完成(url_dispatch)标签位侦听并执行绑定行为
41. 应用开始(app_begin)标签位侦听并执行绑定行为

    1. App.class.php
    2. static public function run() {
    3. // 应用初始化标签
    4. Hook::listen('app_init');
    5. App::init();
    6. // 应用开始标签
    7. Hook::listen('app_begin');

42. 调用SESSION_OPTIONS配置参数进行Session初始化(如果不是命令行模式)

    1. // Session初始化
    2. if(!IS_CLI){
    3. session(C('SESSION_OPTIONS'));
    4. }

43. 根据请求执行控制器方法
44. 如果控制器不存在则检测空控制器是否存在
45. 控制器开始(action_begin)标签位侦听并执行绑定行为

    1. Controller.class.php
    2. public function __construct() {
    3. Hook::listen('action_begin',$this->config);
    4. //实例化视图类
    5. $this->view = Think::instance('Think\View');
    6. //控制器初始化
    7. if(method_exists($this,'_initialize'))
    8. $this->_initialize();
    9. }

46. 默认调用系统的ReadHtmlCache行为读取静态缓存(HTML_CACHE_ON参数开启)
47. 判断并调用控制器的_initialize初始化方法

    1. Controller.class.php
    2. if(method_exists($this,'_initialize'))
    3. $this->_initialize();

48. 判断操作方法是否存在,如果不存在则检测是否定义空操作方法
49. 判断前置操作方法是否定义,有的话执行
50. Action参数绑定检测,自动匹配操作方法的参数
51. 如果有模版渲染(调用控制器display方法)
52. 视图开始(view_begin)标签位侦听并执行绑定行为
53. 调用Think\View的fetch方法解析并获取模版内容

    1. View.class.php

54. 自动识别当前主题以及定位模版文件
55. 视图解析(view_parse)标签位侦听并执行绑定行为

    1. View.class.php
    2.  
    3. Hook::listen('view_parse',$params);
    4. common.php
    5. 'view_parse' => array(
    6. 'Behavior\ParseTemplateBehavior', // 模板解析 支持PHP、内置模板引擎和第三方模板引擎
    7. ),

56. 默认调用内置ParseTemplate行为解析模版(普通模式下面)

    1. View.class.php
    2. public function parseTemplate($template='')

57. 模版引擎解析模版内容后生成模版缓存

58. 模版过滤替换(template_filter)标签位侦听并执行绑定行为

    1. Template.class.php
    2. Hook::listen('template_filter',$tmplContent);

59. 默认调用系统的ContentReplace行为进行模版替换

    1. 'template_filter'=> array(
    2. 'Behavior\ContentReplaceBehavior', // 模板输出替换
    3. ),
    4. ContentReplaceBehavior.class.php
    5. class ContentReplaceBehavior {

60. 输出内容过滤(view_filter)标签位侦听并执行绑定行为

    1. 'view_filter' => array(
    2. 'Behavior\WriteHtmlCacheBehavior', // 写入静态缓存
    3. ),

61. 默认调用系统的WriteHtmlCache行为写入静态缓存(HTML_CACHE_ON参数开启)

    1. WriteHtmlCacheBehavior.class.php
    2. class WriteHtmlCacheBehavior {

62. 调用Think\View类的render方法输出渲染内容
63. 视图结束(view_end)标签位侦听并执行绑定行为

  1. view.class.php

64. 判断后置操作方法是否定义,有的话执行
65. 控制器结束(action_end)标签位侦听并执行绑定行为

    1. Controller.class.php

66. 应用结束(app_end)标签位侦听并执行绑定行为

    1. App.class.php
    2. Hook::listen('app_end');

67. 执行系统的ShowPageTrace行为(SHOW_PAGE_TRACE参数开启并且不是AJAX请求)
68. 日志信息存储写入

ThinkPHP 框架执行流程分析的更多相关文章

  1. 报时机器人的rasa shell执行流程分析

      本文以报时机器人为载体,介绍了报时机器人的对话能力范围.配置文件功能和训练和运行命令,重点介绍了rasa shell命令启动后的程序执行过程. 一.报时机器人项目结构 1.对话能力范围 (1)能够 ...

  2. ThinkPHP中的跨控制器调用与框架执行流程

    一.跨控制器调用 UserController.class.php <?php namespace Home/Controller use Think/Controller class User ...

  3. Android之 MTP框架和流程分析

    概要 本文的目的是介绍Android系统中MTP的一些相关知识.主要的内容包括:第1部分 MTP简介            对Mtp协议进行简单的介绍.第2部分 MTP框架            介绍 ...

  4. spark-sql执行流程分析

    spark-sql 架构 图1 图1是sparksql的执行架构,主要包括逻辑计划和物理计划几个阶段,下面对流程详细分析. sql执行流程 总体流程 parser:基于antlr框架对 sql解析,生 ...

  5. vue2源码框架和流程分析

    vue整体框架和主要流程分析 之前对看过比较多关于vue源码的文章,但是对于整体框架和流程还是有些模糊,最后用chrome debug对vue的源码进行查看整理出这篇文章.... 本文对vue的整体框 ...

  6. 深入浅出Mybatis系列(十)---SQL执行流程分析(源码篇)

    最近太忙了,一直没时间继续更新博客,今天忙里偷闲继续我的Mybatis学习之旅.在前九篇中,介绍了mybatis的配置以及使用, 那么本篇将走进mybatis的源码,分析mybatis 的执行流程, ...

  7. Spring 文件上传MultipartFile 执行流程分析

    在了解Spring 文件上传执行流程之前,我们必须知道两点: 1.Spring 文件上传是基于common-fileUpload 组件的,所以,文件上传必须引入此包 2.Spring 文件上传需要在X ...

  8. [转]两表join的multi update语句在MySQL中的执行流程分析

    出自:http://hedengcheng.com/?p=209 两表join的multi update语句,执行结果与预计不一致的分析过程 — multi update结论在实际应用中,不要轻易使用 ...

  9. Hive SQL执行流程分析

    转自 http://www.tuicool.com/articles/qyUzQj 最近在研究Impala,还是先回顾下Hive的SQL执行流程吧. Hive有三种用户接口: cli (Command ...

随机推荐

  1. JSONModel解析数据成Model

    转自:http://blog.csdn.net/smking/article/details/40432287 JSONModel, Mantle 这两个开源库都是用来进行封装JSON->Mod ...

  2. 管理MySQL的命令

    USE 数据库名 :选择要操作的Mysql数据库,使用该命令后所有Mysql命令都只针对该数据库. SHOW DATABASES: 列出 MySQL 数据库管理系统的数据库列表. SHOW TABLE ...

  3. redis3--key的操作

    我们之前使用Redis简单存储了三个参数:在语句set name jack中,其中name就是一个key.我们Java中的变量名是有一定规则的,比如组成内容可以是"数字",&quo ...

  4. CentOS 6.4 系统下的MySQL的主从库配置

    首先了解到一. 二一.(MySQL下创建用户并且赋予权限)root用户创建yong用户的SQL语句 CREATE USER 'yong'@'localhost' IDENTIFIED BY 'yong ...

  5. eclipse代码提示优化

    用Eclipse编写Android程序的代码提示功能主要是在java和xml文件中,有时候会失效,默认的提示功能有限. 1)java文件自动提示      Window->Preferences ...

  6. python实现邮件发送完整代码(带附件发送方式)

    实例一:利用SMTP与EMAIL实现邮件发送,带附件(完整代码) __author__ = 'Administrator'#coding=gb2312 from email.Header import ...

  7. linux 架设 postfix 邮件服务器

    http://www.cnblogs.com/dudu/archive/2012/12/12/linux-postfix-mailserver.html

  8. contact form

    use the existing service: http://www.foxyform.com/

  9. linux tar包追加问题【转】

    只能已归档的文件才能追加文件. 如果tar.gz文件是如此生成:#tar -zcvf test.tar.gz  a.txt即tar.gz是压缩(-z)和归档(-c)文件,则无法给它追加文件:若果tar ...

  10. MySQL源码安装(centos)

    1.去MySQL官网下载源码包 地址:http://dev.mysql.com/downloads/mysql/ 下载完后需要检查文件的MD5,以确认是否从官网下载的原版本(以防被人篡改过该软件) 使 ...