轉載請註明出處,謝謝。
框架目錄
3.2的版本
- |—ThinkPHP框架目錄(能將其部署在非Web目錄下)
- |——Common 核心公共函數
- |——Conf 核心配置目錄
- |——Lang 核心語言包目錄
- |——Library 框架類庫目錄
- |———Think 核心Think類庫包目錄
- |———Behavior 行爲類庫目錄
- |———Org Org類庫包目錄
- |———Vendor 第三方類庫目錄
- |———… 更多類庫目錄
- |——Extend 框架擴展目錄
- |——Tpl 系統模板目錄
- |——LICENSE.txt 系統類庫映射文件
- |——logo.png 框架LOGO文件
- |——README.txt 框架README文件
- |——index.php 框架入口文件
應用入口文件和Public資源目錄外,其他文件都放到非WEB目錄下面,具有更好的安全性。
系統流程
- 用戶URL請求
- 調用應用入口文件(通常是網站的index.php)
- 載入框架入口文件(ThinkPHP.php)
- 記錄初始運行時間和內存開銷
- 系統常量判斷及定義
- 載入框架引導類(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();
- 設置錯誤處理機制和自動加載機制
- 調用Think\Storage類進行存儲初始化(由STORAGE_TYPE常量定義存儲類型)
- 部署模式下如果存在應用編譯緩存文件則直接加載(直接跳轉到步驟22)
- 讀取應用模式(由APP_MODE常量定義)的定義文件(以下以普通模式爲例說明)
- 加載當前應用模式定義的核心文件(普通模式是 ThinkPHP/Conf/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)
- 判斷應用狀態並讀取狀態配置文件(如果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_ROUTER_ON開啓)
- PATH_INFO處理(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行爲(SHOW_PAGE_TRACE參數開啓並且不是AJAX請求)
- 日誌信息存儲寫入
如果是部署模式下面的第二次請求的話,上面的流程中的步驟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;
}