1. 程式人生 > 程式設計 >Laravel框架原始碼解析之入口檔案原理分析

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程式設計有所幫助。