Laravel框架原始碼解析之入口檔案原理分析
本文例項講述了Laravel框架原始碼解析之入口檔案原理。分享給大家供大家參考,具體如下:
前言
提升能力的方法並非使用更多工具,而是解刨自己所使用的工具。今天我們從Laravel啟動的第一步開始講起。
入口檔案
laravel是單入口框架,所有請求必將經過index.php
define('LARAVEL_START',microtime(true)); // 獲取啟動時間
使用composer是現代PHP的標誌
require __DIR__.'/../vendor/autoload.php'; // 載入composer -> autoload.php
載入啟動檔案
$app = require_once __DIR__.'/../bootstrap/app.php';
獲取$app
是laravel啟動的關鍵,也可以說$app是用於啟動laravel核心的鑰匙🔑。隨後就是載入核心,載入服務提供者、門面所對映的實體類,中介軟體,最後到接收http請求並返回結果。
$kernel = $app->make(Illuminate\Contracts\Http\Kernel::class); // 載入核心類 $response = $kernel->handle( $request = Illuminate\Http\Request::capture() ); $response->send(); $kernel->terminate($request,$response);
看似短短的4行程式碼,這則是laravel的優雅之處。我們開始深層次解刨。
bootstrap\app.php
這個啟動檔案也可以看作是一個服務提供者,不過他並沒有boot,register方法。因為入口檔案直接載入他,所有這些沒必要的方法就不存在了。
作為啟動檔案,首頁則是載入框架所有必須的要要件,例如
- registerBaseBindings
- registerBaseServiceProviders
- registerCoreContainerAliases,
這其中包括了很多基礎性的方法和類,例如
- db
[\Illuminate\Database\DatabaseManager::class]
- auth
[\Illuminate\Auth\AuthManager::class,\Illuminate\Contracts\Auth\Factory::class]
- log
[\Illuminate\Log\LogManager::class,\Psr\Log\LoggerInterface::class]
- queue
[\Illuminate\Queue\QueueManager::class,\Illuminate\Contracts\Queue\Factory::class,\Illuminate\Contracts\Queue\Monitor::class]
- redis
[\Illuminate\Redis\RedisManager::class,\Illuminate\Contracts\Redis\Factory::class]
- 等等
...
而$app這個在服務提供者的核心變數則就是Application例項化所得,而你在服務提供者內使用的make,bind,singleton來自他的父類Container,都說容器是laravel的核心概念。這塊的概念後續我們會詳細的講解。
$app = new Illuminate\Foundation\Application( realpath(__DIR__.'/../') );
上面我們已經獲得$app的例項化了,現在通過$app來註冊核心類、異常類,並將$app返回給index.php
$app->singleton( Illuminate\Contracts\Http\Kernel::class,App\Http\Kernel::class ); $app->singleton( Illuminate\Contracts\Console\Kernel::class,App\Console\Kernel::class ); $app->singleton( Illuminate\Contracts\Debug\ExceptionHandler::class,App\Exceptions\Handler::class );
App\Http\Kernel
核心類了所有的
- 系統中介軟體
- 群組中介軟體
- 路由中介軟體
當然你需要使用中介軟體也是在這個類中載入,是經常被使用的一個檔案。
protected $middleware = [ \Illuminate\Foundation\Http\Middleware\CheckForMaintenanceMode::class,\Illuminate\Foundation\Http\Middleware\ValidatePostSize::class,\App\Http\Middleware\TrimStrings::class,\Illuminate\Foundation\Http\Middleware\ConvertEmptyStringsToNull::class,\App\Http\Middleware\TrustProxies::class,]; /** * The application's route middleware groups. * * @var array */ protected $middlewareGroups = [ 'web' => [ \App\Http\Middleware\EncryptCookies::class,\Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,\Illuminate\Session\Middleware\StartSession::class,// \Illuminate\Session\Middleware\AuthenticateSession::class,\Illuminate\View\Middleware\ShareErrorsFromSession::class,\App\Http\Middleware\VerifyCsrfToken::class,\Illuminate\Routing\Middleware\SubstituteBindings::class,],'api' => [ 'throttle:60,1','bindings',];
這個核心類繼承自他的父類Illuminate\Foundation\Http\Kernel::class
,核心類做了很多事情,它會將所有的中介軟體全部儲存到一個指定的陣列,方便核心呼叫及其他類呼叫。
namespace App\Http; use App\Api\Middleware\VerifyApiToken; use Illuminate\Foundation\Http\Kernel as HttpKernel; class Kernel extends HttpKernel
回到起點
Laravel的啟動經歷了很繁瑣的一個過程。這也是Laravel優雅的關鍵點。
$response = $kernel->handle( $request = Illuminate\Http\Request::capture() ); $response->send(); $kernel->terminate($request,$response);
將請求傳入則完成了整個laravel的啟動,至於結果的返回則有開發者自行通過控制器或其他可訪問類返回。
更多關於Laravel相關內容感興趣的讀者可檢視本站專題:《Laravel框架入門與進階教程》、《php優秀開發框架總結》、《php面向物件程式設計入門教程》、《php+mysql資料庫操作入門教程》及《php常見資料庫操作技巧彙總》
希望本文所述對大家基於Laravel框架的PHP程式設計有所幫助。