thinkphp目錄結構與系統流程

轉載請註明出處,謝謝。

框架目錄

3.2的版本

  1. |—ThinkPHP框架目錄(能將其部署在非Web目錄下)
  2. |——Common           核心公共函數
  3. |——Conf                   核心配置目錄
  4. |——Lang                   核心語言包目錄
  5. |——Library               框架類庫目錄
  6. |———Think              核心Think類庫包目錄
  7. |———Behavior        行爲類庫目錄
  8. |———Org                 Org類庫包目錄
  9. |———Vendor           第三方類庫目錄
  10. |———…                     更多類庫目錄
  11. |——Extend                框架擴展目錄
  12. |——Tpl                      系統模板目錄
  13. |——LICENSE.txt       系統類庫映射文件
  14. |——logo.png           框架LOGO文件
  15. |——README.txt      框架README文件
  16. |——index.php          框架入口文件
    應用入口文件和Public資源目錄外,其他文件都放到非WEB目錄下面,具有更好的安全性。

系統流程

  1. 用戶URL請求
  2. 調用應用入口文件(通常是網站的index.php)
  3. 載入框架入口文件(ThinkPHP.php)
  4. 記錄初始運行時間和內存開銷
  5. 系統常量判斷及定義
  6. 載入框架引導類(Think\Think)並執行Think::start方法進行應用初始化
<?php
// +----------------------------------------------------------------------
// | ThinkPHP [ WE CAN DO IT JUST THINK IT ]
// +----------------------------------------------------------------------
// | Copyright (c) 2006-2014 http://thinkphp.cn All rights reserved.
// +----------------------------------------------------------------------
// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
// +----------------------------------------------------------------------
// | Author: liu21st <[email protected]>
// +----------------------------------------------------------------------

//----------------------------------
// ThinkPHP公共入口文件
//----------------------------------

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

// 版本信息
const THINK_VERSION     =   '3.2.2';

// URL 模式定義
const URL_COMMON        =   0;  //普通模式
const URL_PATHINFO      =   1;  //PATHINFO模式
const URL_REWRITE       =   2;  //REWRITE模式
const URL_COMPAT        =   3;  // 兼容模式

// 類文件後綴
const EXT               =   '.class.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); // 是否調試模式

if(function_exists('saeAutoLoader')){// 自動識別SAE環境
    defined('APP_MODE')     or define('APP_MODE',      'sae');
    defined('STORAGE_TYPE') or define('STORAGE_TYPE',  'Sae');
}else{
    defined('APP_MODE')     or define('APP_MODE',       'common'); // 應用模式 默認爲普通模式    
    defined('STORAGE_TYPE') or define('STORAGE_TYPE',   'File'); // 存儲類型 默認爲File    
}

defined('RUNTIME_PATH') or define('RUNTIME_PATH',   APP_PATH.'Runtime/');   // 系統運行時目錄
defined('LIB_PATH')     or define('LIB_PATH',       realpath(THINK_PATH.'Library').'/'); // 系統核心類庫目錄
defined('CORE_PATH')    or define('CORE_PATH',      LIB_PATH.'Think/'); // Think類庫目錄
defined('BEHAVIOR_PATH')or define('BEHAVIOR_PATH',  LIB_PATH.'Behavior/'); // 行爲類庫目錄
defined('MODE_PATH')    or define('MODE_PATH',      THINK_PATH.'Mode/'); // 系統應用模式目錄
defined('VENDOR_PATH')  or define('VENDOR_PATH',    LIB_PATH.'Vendor/'); // 第三方類庫目錄
defined('COMMON_PATH')  or define('COMMON_PATH',    APP_PATH.'Common/'); // 應用公共目錄
defined('CONF_PATH')    or define('CONF_PATH',      COMMON_PATH.'Conf/'); // 應用配置目錄
defined('LANG_PATH')    or define('LANG_PATH',      COMMON_PATH.'Lang/'); // 應用語言目錄
defined('HTML_PATH')    or define('HTML_PATH',      APP_PATH.'Html/'); // 應用靜態目錄
defined('LOG_PATH')     or define('LOG_PATH',       RUNTIME_PATH.'Logs/'); // 應用日誌目錄
defined('TEMP_PATH')    or define('TEMP_PATH',      RUNTIME_PATH.'Temp/'); // 應用緩存目錄
defined('DATA_PATH')    or define('DATA_PATH',      RUNTIME_PATH.'Data/'); // 應用數據目錄
defined('CACHE_PATH')   or define('CACHE_PATH',     RUNTIME_PATH.'Cache/'); // 應用模板緩存目錄
defined('CONF_EXT')     or define('CONF_EXT',       '.php'); // 配置文件後綴
defined('CONF_PARSE')   or define('CONF_PARSE',     '');    // 配置文件解析方法

// 系統信息
if(version_compare(PHP_VERSION,'5.4.0','<')) {
    ini_set('magic_quotes_runtime',0);
    define('MAGIC_QUOTES_GPC',get_magic_quotes_gpc()?True:False);
}else{
    define('MAGIC_QUOTES_GPC',false);
}
define('IS_CGI',(0 === strpos(PHP_SAPI,'cgi') || false !== strpos(PHP_SAPI,'fcgi')) ? 1 : 0 );
define('IS_WIN',strstr(PHP_OS, 'WIN') ? 1 : 0 );
define('IS_CLI',PHP_SAPI=='cli'? 1   :   0);

if(!IS_CLI) {
    // 當前文件名
    if(!defined('_PHP_FILE_')) {
        if(IS_CGI) {
            //CGI/FASTCGI模式下
            $_temp  = explode('.php',$_SERVER['PHP_SELF']);
            define('_PHP_FILE_',    rtrim(str_replace($_SERVER['HTTP_HOST'],'',$_temp[0].'.php'),'/'));
        }else {
            define('_PHP_FILE_',    rtrim($_SERVER['SCRIPT_NAME'],'/'));
        }
    }
    if(!defined('__ROOT__')) {
        $_root  =   rtrim(dirname(_PHP_FILE_),'/');
        define('__ROOT__',  (($_root=='/' || $_root=='\\')?'':$_root));
    }
}

// 加載核心Think類
require CORE_PATH.'Think'.EXT;
// 應用初始化 
Think\Think::start();
  1. 設置錯誤處理機制和自動加載機制
  2. 調用Think\Storage類進行存儲初始化(由STORAGE_TYPE常量定義存儲類型)
  3. 部署模式下如果存在應用編譯緩存文件則直接加載(直接跳轉到步驟22)
  4. 讀取應用模式(由APP_MODE常量定義)的定義文件(以下以普通模式爲例說明)
  5. 加載當前應用模式定義的核心文件(普通模式是 ThinkPHP/Conf/Mode/common.php)
  6. 加載慣例配置文件(普通模式是 ThinkPHP/Conf/convention.php)
  7. 加載應用配置文件(普通模式是 Application/Common/Conf/config.php)
  8. 加載系統別名定義
  9. 判斷並讀取應用別名定義文件(普通模式是 Application/Common/Conf/alias.php)
  10. 加載系統行爲定義
  11. 判斷並讀取應用行爲定義文件(普通模式是 Application/Common/Conf/tags.php)
  12. 加載框架底層語言包(普通模式是 ThinkPHP/Lang/zh-cn.php)
  13. 如果是部署模式則生成應用編譯緩存文件
  14. 加載調試模式系統配置文件(ThinkPHP/Conf/debug.php)
  15. 判斷並讀取應用的調試配置文件(默認是 Application/Common/Conf/debug.php)
  16. 判斷應用狀態並讀取狀態配置文件(如果APP_STATUS常量定義不爲空的話)
  17. 檢測應用目錄結構並自動生成(如果CHECK_APP_DIR配置開啓並且RUNTIME_PATH目錄不存在的情況下)
  18. 調用Think\App類的run方法啓動應用
  19. 應用初始化(app_init)標籤位偵聽並執行綁定行爲
  20. 判斷並加載動態配置和函數文件
  21. 調用Think\Dispatcher::dispatch方法進行URL請求調度
  22. 自動識別兼容URL模式和命令行模式下面的$_SERVER[‘PATH_INFO’]參數
  23. 檢測域名部署以及完成模塊和控制器的綁定操作(APP_SUB_DOMAIN_DEPLOY參數開啓)
  24. 分析URL地址中的PATH_INFO信息
  25. 獲取請求的模塊信息
  26. 檢測模塊是否存在和允許訪問
  27. 判斷並加載模塊配置文件、別名定義、行爲定義及函數文件
  28. 判斷並加載模塊的動態配置和函數文件
  29. 模塊的URL模式判斷
  30. 模塊的路由檢測(URL_ROUTER_ON開啓)
  31. PATH_INFO處理(path_info)標籤位偵聽並執行綁定行爲
  32. URL後綴檢測(URL_DENY_SUFFIX以及URL_HTML_SUFFIX處理)
  33. 獲取當前控制器和操作,以及URL其他參數
  34. URL請求調度完成(url_dispatch)標籤位偵聽並執行綁定行爲
  35. 應用開始(app_begin)標籤位偵聽並執行綁定行爲
  36. 調用SESSION_OPTIONS配置參數進行Session初始化(如果不是命令行模式)
  37. 根據請求執行控制器方法
  38. 如果控制器不存在則檢測空控制器是否存在
  39. 控制器開始(action_begin)標籤位偵聽並執行綁定行爲
  40. 默認調用系統的ReadHtmlCache行爲讀取靜態緩存(HTML_CACHE_ON參數開啓)
  41. 判斷並調用控制器的_initialize初始化方法
  42. 判斷操作方法是否存在,如果不存在則檢測是否定義空操作方法
  43. 判斷前置操作方法是否定義,有的話執行
  44. Action參數綁定檢測,自動匹配操作方法的參數
  45. 如果有模版渲染(調用控制器display方法)
  46. 視圖開始(view_begin)標籤位偵聽並執行綁定行爲
  47. 調用Think\View的fetch方法解析並獲取模版內容
  48. 自動識別當前主題以及定位模版文件
  49. 視圖解析(view_parse)標籤位偵聽並執行綁定行爲
  50. 默認調用內置ParseTemplate行爲解析模版(普通模式下面)
  51. 模版引擎解析模版內容後生成模版緩存
  52. 模版過濾替換(template_filter)標籤位偵聽並執行綁定行爲
  53. 默認調用系統的ContentReplace行爲進行模版替換
  54. 輸出內容過濾(view_filter)標籤位偵聽並執行綁定行爲
  55. 默認調用系統的WriteHtmlCache行爲寫入靜態緩存(HTML_CACHE_ON參數開啓)
  56. 調用Think\View類的render方法輸出渲染內容
  57. 視圖結束(view_end)標籤位偵聽並執行綁定行爲
  58. 判斷後置操作方法是否定義,有的話執行
  59. 控制器結束(action_end)標籤位偵聽並執行綁定行爲
  60. 應用結束(app_end)標籤位偵聽並執行綁定行爲
  61. 執行系統的ShowPageTrace行爲(SHOW_PAGE_TRACE參數開啓並且不是AJAX請求)
  62. 日誌信息存儲寫入

如果是部署模式下面的第二次請求的話,上面的流程中的步驟10( 10. 讀取應用模式(由APP_MODE常量定義)的定義文件(以下以普通模式爲例說明))~21可以省略。


16調用Think\Dispatcher::dispatch方法進行URL請求調度

<?php
   /**
     * 輸出內容文本可以包括Html
     * @access private
     * @param string $content 輸出內容
     * @param string $charset 模板輸出字符集
     * @param string $contentType 輸出類型
     * @return mixed
     */
    private function render($content,$charset='',$contentType=''){
        if(empty($charset))  $charset = C('DEFAULT_CHARSET');
        if(empty($contentType)) $contentType = C('TMPL_CONTENT_TYPE');
        // 網頁字符編碼
        header('Content-Type:'.$contentType.'; charset='.$charset);
        header('Cache-control: '.C('HTTP_CACHE_CONTROL'));  // 頁面緩存控制
        header('X-Powered-By:ThinkPHP');
        // 輸出模板文件
        echo $content;
    }
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章