Laravel原始碼解析之入口,程式設計師必學
前言 提升能力的方法並非使用更多工具,而是解刨自己所使用的工具。今天我們從Laravel啟動的第一步開始講起。
入口檔案 laravel是單入口框架,所有請求必將經過index.php
define(‘LARAVEL_START’, microtime(true)); // 獲取啟動時間 使用composer是現代PHP的標誌
require DIR.’/…/vendor/autoload.php’; // 載入composer -> autoload.php 載入啟動檔案
KaTeX parse error: Expected group after '_' at position 20: …= require_once _̲_DIR__.'/../boo…
$kernel = $app->make(Illuminate\Contracts\Http\Kernel::class); // 載入核心類
$response = $kernel->handle( $request = Illuminate\Http\Request::capture() );
$response->send();
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的核心概念。這塊的概念後續我們會詳細的講解。
KaTeX parse error: Expected 'EOF', got '\Foundation' at position 21: … new Illuminate\̲F̲o̲u̲n̲d̲a̲t̲i̲o̲n̲\Application( …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();
request, $response); 將請求傳入則完成了整個laravel的啟動,至於結果的返回則有開發者自行通過控制器或其他可訪問類返回。 !
更多資源請掃碼關注下載