thinkphp源碼分析(二)—入口篇

源碼分析---入口篇

源碼分析

應用入口

用戶發起的請求都會通過應用的入口文件,一般是 ==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();源碼分析

相關文章
相關標籤/搜索