ThinkPHP 框架執行流程分析

整體來講,應用的流程涉及到幾個文件:
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. 記錄初始運行時間和內存開銷php

(引用自ThinkPHP.php) // 記錄開始運行時間
$GLOBALS['_beginTime'] = microtime(TRUE); // 記錄內存初始使用
define('MEMORY_LIMIT_ON',function_exists('memory_get_usage')); if(MEMORY_LIMIT_ON) $GLOBALS['_startUseMems'] = memory_get_usage();

5. 系統常量判斷及定義緩存

(引用自ThinkPHP.php) // 系統常量定義
defined('THINK_PATH')   or define('THINK_PATH',     __DIR__.'/'); defined('APP_PATH')     or define('APP_PATH',       dirname($_SERVER['SCRIPT_FILENAME']).'/'); defined('APP_STATUS')   or define('APP_STATUS',     ''); // 應用狀態 加載對應的配置文件
defined('APP_DEBUG')    or define('APP_DEBUG',      false); // 是否調試模式

6. 載入框架引導類(Think\Think)並執行Think::start方法進行應用初始化php框架

(引用自ThinkPHP.php) // 應用初始化 
Think\Think::start();

7. 設置錯誤處理機制和自動加載機制session

(引用Think.class.php) // 註冊AUTOLOAD方法
      spl_autoload_register('Think\Think::autoload'); // 設定錯誤和異常處理
      register_shutdown_function('Think\Think::fatalError'); set_error_handler('Think\Think::appError'); set_exception_handler('Think\Think::appException');

8. 調用Think\Storage類進行存儲初始化(由STORAGE_TYPE常量定義存儲類型)app

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

9. 部署模式下若是存在應用編譯緩存文件則直接加載(直接跳轉到步驟22)框架

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

10. 讀取應用模式(由APP_MODE常量定義)的定義文件(如下以普通模式爲例說明)
Thinkphp框架默認的應用模式 爲普通模式。函數

  1. (引用Think.class.php)

    // 讀取應用模式 $mode = include is_file(CONF_PATH.'core.php')?CONF_PATH.'core.php':MODE_PATH.APP_MODE.'.php';

11. 加載當前應用模式定義的核心文件(普通模式是 ThinkPHP/Mode/common.php)fetch

  1. (common.php) THINK_PATH.'Conf/convention.php',   // 系統慣例配置
    CONF_PATH.'config'.CONF_EXT,      // 應用公共配置

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

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

14. 加載系統別名定義網站

  1. (common.php) // 別名定義
        'alias'     =>  array( 'Think\Log'               => CORE_PATH . 'Log'.EXT,
            'Think\Log\Driver\File'   => CORE_PATH . 'Log/Driver/File'.EXT,
            'Think\Exception'         => CORE_PATH . 'Exception'.EXT,
            'Think\Model'             => CORE_PATH . 'Model'.EXT,
            'Think\Db'                => CORE_PATH . 'Db'.EXT,
            'Think\Template'          => CORE_PATH . 'Template'.EXT,
            'Think\Cache'             => CORE_PATH . 'Cache'.EXT,
            'Think\Cache\Driver\File' => CORE_PATH . 'Cache/Driver/File'.EXT,
            'Think\Storage'           => CORE_PATH . 'Storage'.EXT, ),

15. 判斷並讀取應用別名定義文件(普通模式是 Application/Common/Conf/alias.php)
16. 加載系統行爲定義
17. 判斷並讀取應用行爲定義文件(普通模式是 Application/Common/Conf/tags.php)ui

  1. (tags.php) '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) // 讀取當前應用狀態對應的配置文件
       if(APP_STATUS && is_file(CONF_PATH.APP_STATUS.CONF_EXT)) C(include CONF_PATH.APP_STATUS.CONF_EXT);   

23. 檢測應用目錄結構並自動生成(若是CHECK_APP_DIR配置開啓而且RUNTIME_PATH目錄不存在的狀況下)

  1. think.class.php // 檢查應用目錄結構 若是不存在則自動建立
          if(C('CHECK_APP_DIR')) { $module     =   defined('BIND_MODULE') ? BIND_MODULE : C('DEFAULT_MODULE'); if(!is_dir(APP_PATH.$module) || !is_dir(LOG_PATH)){ // 檢測應用目錄結構
                  Build::checkDir($module); } }

24. 調用Think\App類的run方法啓動應用

  1. think.class.php // 運行應用
          App::run();

25. 應用初始化(app_init)標籤位偵聽並執行綁定行爲
26. 判斷並加載動態配置和函數文件
27. 調用Think\Dispatcher::dispatch方法進行URL請求調度

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

28. 自動識別兼容URL模式和命令行模式下面的$_SERVER['PATH_INFO']參數

  1. Dispatcher.class.php $_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 static public function run() { // 應用初始化標籤
            Hook::listen('app_init'); App::init(); // 應用開始標籤
            Hook::listen('app_begin');

42. 調用SESSION_OPTIONS配置參數進行Session初始化(若是不是命令行模式)

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

43. 根據請求執行控制器方法
44. 若是控制器不存在則檢測空控制器是否存在
45. 控制器開始(action_begin)標籤位偵聽並執行綁定行爲

  1. Controller.class.php public function __construct() { Hook::listen('action_begin',$this->config); //實例化視圖類
            $this->view     = Think::instance('Think\View'); //控制器初始化
            if(method_exists($this,'_initialize')) $this->_initialize(); }

46. 默認調用系統的ReadHtmlCache行爲讀取靜態緩存(HTML_CACHE_ON參數開啓)
47. 判斷並調用控制器的_initialize初始化方法

  1. Controller.class.php if(method_exists($this,'_initialize')) $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 Hook::listen('view_parse',$params); common.php 'view_parse'    =>  array( 'Behavior\ParseTemplateBehavior', // 模板解析 支持PHP、內置模板引擎和第三方模板引擎
            ),

56. 默認調用內置ParseTemplate行爲解析模版(普通模式下面)

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

57. 模版引擎解析模版內容後生成模版緩存

58. 模版過濾替換(template_filter)標籤位偵聽並執行綁定行爲

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

59. 默認調用系統的ContentReplace行爲進行模版替換

  1. 'template_filter'=> array( 'Behavior\ContentReplaceBehavior', // 模板輸出替換
            ), ContentReplaceBehavior.class.php class ContentReplaceBehavior {

60. 輸出內容過濾(view_filter)標籤位偵聽並執行綁定行爲

  1. 'view_filter'   =>  array( 'Behavior\WriteHtmlCacheBehavior', // 寫入靜態緩存
            ),

61. 默認調用系統的WriteHtmlCache行爲寫入靜態緩存(HTML_CACHE_ON參數開啓)

  1. WriteHtmlCacheBehavior.class.php class WriteHtmlCacheBehavior {

62. 調用Think\View類的render方法輸出渲染內容
63. 視圖結束(view_end)標籤位偵聽並執行綁定行爲

view.class.php

64. 判斷後置操做方法是否認義,有的話執行
65. 控制器結束(action_end)標籤位偵聽並執行綁定行爲

  1. Controller.class.php

66. 應用結束(app_end)標籤位偵聽並執行綁定行爲

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

67. 執行系統的ShowPageTrace行爲(SHOW_PAGE_TRACE參數開啓而且不是AJAX請求)
68. 日誌信息存儲寫入

相關文章
相關標籤/搜索