用戶發起的請求都會通過應用的入口文件,一般是 ==public/index.php==文件。固然,你也能夠更改或者增長新的入口文件。php
一般入口文件的代碼都比較簡單,一個普通的入口文件代碼以下:thinkphp
// 應用入口文件 // 定義項目路徑 define('APP_PATH', __DIR__ . '/../application/'); // 加載框架引導文件 require __DIR__ . '/../thinkphp/start.php';
通常入口文件以定義一些常量爲主,支持的常量請參考後續的內容或者附錄部分。一般,咱們不建議在應用入口文件中加入過多的代碼,尤爲是和業務邏輯相關的代碼。app
// ThinkPHP 引導文件 // 1. 加載基礎文件 require __DIR__ . '/base.php'; // 2. 執行應用 App::run()->send();
// __DIR__ . '/base.php'文件 //定義常量 define('THINK_VERSION', '5.0.24'); ....//常量太多省略了部分 // 載入Loader類 require CORE_PATH . 'Loader.php'; // 加載環境變量配置文件 if (is_file(ROOT_PATH . '.env')) { $env = parse_ini_file(ROOT_PATH . '.env', true); foreach ($env as $key => $val) { $name = ENV_PREFIX . strtoupper($key); if (is_array($val)) { foreach ($val as $k => $v) { $item = $name . '_' . strtoupper($k); putenv("$item=$v"); } } else { putenv("$name=$val"); } } } // 註冊自動加載 \think\Loader::register(); // 註冊錯誤和異常處理機制 \think\Error::register(); // 加載慣例配置文件 \think\Config::set(include THINK_PATH . 'convention' . EXT);
該部分主要是定義一些系統常量,關鍵點是引入了自動加載類而且註冊了自動加載,使得框架能夠自動引入類文件,業務層只要直接use對應命名空間的類便可進行實例化,註冊錯誤及異常處理機制, 加載默認配置等操做。框架
最後就是應用啓動,App::run()->send();源碼分析