本文實例講述了Laravel框架源碼解析之入口文件原理。分享給大家供大家參考,具體如下:
提升能力的方法并非使用更多工具,而是解刨自己所使用的工具。今天我們從Laravel啟動的第一步開始講起。
laravel是單入口框架,所有請求必將經(jīng)過index.php
define('LARAVEL_START', microtime(true)); // 獲取啟動時間
使用composer是現(xiàn)代PHP的標(biāo)志
require __DIR__.'/../vendor/autoload.php'; // 加載composer -> autoload.php
加載啟動文件
$app = require_once __DIR__.'/../bootstrap/app.php';
獲取$app
是laravel啟動的關(guān)鍵,也可以說$app是用于啟動laravel內(nèi)核的鑰匙🔑。隨后就是加載內(nèi)核,載入服務(wù)提供者、門面所映射的實體類,中間件,最后到接收http請求并返回結(jié)果。
$kernel = $app->make(Illuminate\Contracts\Http\Kernel::class); // 加載核心類 $response = $kernel->handle( $request = Illuminate\Http\Request::capture() ); $response->send(); $kernel->terminate($request, $response);
看似短短的4行代碼,這則是laravel的優(yōu)雅之處。我們開始深層次解刨。
這個啟動文件也可以看作是一個服務(wù)提供者,不過他并沒有boot,register方法。因為入口文件直接加載他,所有這些沒必要的方法就不存在了。
作為啟動文件,首頁則是加載框架所有必須的要要件,例如
這其中包括了很多基礎(chǔ)性的方法和類,例如
[\Illuminate\Database\DatabaseManager::class]
[\Illuminate\Auth\AuthManager::class, \Illuminate\Contracts\Auth\Factory::class]
[\Illuminate\Log\LogManager::class, \Psr\Log\LoggerInterface::class]
[\Illuminate\Queue\QueueManager::class, \Illuminate\Contracts\Queue\Factory::class, \Illuminate\Contracts\Queue\Monitor::class]
[\Illuminate\Redis\RedisManager::class, \Illuminate\Contracts\Redis\Factory::class]
...
而$app這個在服務(wù)提供者的核心變量則就是Application實例化所得,而你在服務(wù)提供者內(nèi)使用的make,bind,singleton來自他的父類Container,都說容器是laravel的核心概念。這塊的概念后續(xù)我們會詳細(xì)的講解。
$app = new Illuminate\Foundation\Application( realpath(__DIR__.'/../') );
上面我們已經(jīng)獲得$app的實例化了,現(xiàn)在通過$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 );
核心類了所有的
當(dāng)然你需要使用中間件也是在這個類中加載,是經(jīng)常被使用的一個文件。
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
,核心類做了很多事情,它會將所有的中間件全部存儲到一個指定的數(shù)組,方便內(nèi)核調(diào)用及其他類調(diào)用。
namespace App\Http; use App\Api\Middleware\VerifyApiToken; use Illuminate\Foundation\Http\Kernel as HttpKernel; class Kernel extends HttpKernel
Laravel的啟動經(jīng)歷了很繁瑣的一個過程。這也是Laravel優(yōu)雅的關(guān)鍵點。
$response = $kernel->handle( $request = Illuminate\Http\Request::capture() ); $response->send(); $kernel->terminate($request, $response);
將請求傳入則完成了整個laravel的啟動,至于結(jié)果的返回則有開發(fā)者自行通過控制器或其他可訪問類返回。
更多關(guān)于Laravel相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Laravel框架入門與進(jìn)階教程》、《php優(yōu)秀開發(fā)框架總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計入門教程》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家基于Laravel框架的PHP程序設(shè)計有所幫助。
標(biāo)簽:隴南 平頂山 河南 武漢 唐山 通遼 南通 黃山
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Laravel框架源碼解析之入口文件原理分析》,本文關(guān)鍵詞 Laravel,框架,源碼,解析,之,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。