当前位置:首页 > CMS教程 > 其它CMS > 列表

Laravel框架源码解析之入口文件原理分析

发布:smiling 来源: PHP粉丝网  添加日期:2022-03-06 11:43:03 浏览: 评论:0 

本文实例讲述了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请求并返回结果。

  1. $kernel = $app->make(Illuminate\Contracts\Http\Kernel::class); // 加载核心类 
  2.  
  3. $response = $kernel->handle( 
  4.  $request = Illuminate\Http\Request::capture() 
  5. ); 
  6.  
  7. $response->send(); 
  8.  
  9. $kernel->terminate($request$response); 

看似短短的4行代码,这则是laravel的优雅之处,我们开始深层次解刨。

bootstrap\app.php

这个启动文件也可以看作是一个服务提供者,不过他并没有boot,register方法。因为入口文件直接加载他,所有这些没必要的方法就不存在了。

作为启动文件,首页则是加载框架所有必须的要要件,例如

registerBaseBindings

registerBaseServiceProviders

registerCoreContainerAliases,

这其中包括了很多基础性的方法和类,例如

  1. db [\Illuminate\Database\DatabaseManager::class
  2. auth [\Illuminate\Auth\AuthManager::class, \Illuminate\Contracts\Auth\Factory::class
  3. log [\Illuminate\Log\LogManager::class, \Psr\Log\LoggerInterface::class
  4. queue [\Illuminate\Queue\QueueManager::class, \Illuminate\Contracts\Queue\Factory::class, \Illuminate\Contracts\Queue\Monitor::class
  5. redis [\Illuminate\Redis\RedisManager::class, \Illuminate\Contracts\Redis\Factory::class

等等 ...

而$app这个在服务提供者的核心变量则就是Application实例化所得,而你在服务提供者内使用的make,bind,singleton来自他的父类Container,都说容器是laravel的核心概念。这块的概念后续我们会详细的讲解。

  1. $app = new Illuminate\Foundation\Application( 
  2.  realpath(__DIR__.'/../'
  3. ); 

上面我们已经获得$app的实例化了,现在通过$app来注册核心类、异常类,并将$app返回给index.php

  1. $app->singleton( 
  2.  Illuminate\Contracts\Http\Kernel::class
  3.  App\Http\Kernel::class 
  4. ); 
  5.  
  6. $app->singleton( 
  7.  Illuminate\Contracts\Console\Kernel::class
  8.  App\Console\Kernel::class 
  9. ); 
  10.  
  11. $app->singleton( 
  12.  Illuminate\Contracts\Debug\ExceptionHandler::class
  13.  App\Exceptions\Handler::class 
  14. ); 
  15.  
  16. App\Http\Kernel 

核心类了所有的

系统中间件

群组中间件

路由中间件

当然你需要使用中间件也是在这个类中加载,是经常被使用的一个文件。

  1. protected $middleware = [ 
  2.    \Illuminate\Foundation\Http\Middleware\CheckForMaintenanceMode::class
  3.    \Illuminate\Foundation\Http\Middleware\ValidatePostSize::class
  4.    \App\Http\Middleware\TrimStrings::class
  5.    \Illuminate\Foundation\Http\Middleware\ConvertEmptyStringsToNull::class
  6.    \App\Http\Middleware\TrustProxies::class
  7.   ]; 
  8.     
  9.   /** 
  10.    * The application's route middleware groups. 
  11.    * 
  12.    * @var array 
  13.    */ 
  14.   protected $middlewareGroups = [ 
  15.    'web' => [ 
  16.     \App\Http\Middleware\EncryptCookies::class
  17.     \Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class
  18.     \Illuminate\Session\Middleware\StartSession::class
  19.     // \Illuminate\Session\Middleware\AuthenticateSession::class, 
  20.     \Illuminate\View\Middleware\ShareErrorsFromSession::class
  21.     \App\Http\Middleware\VerifyCsrfToken::class
  22.     \Illuminate\Routing\Middleware\SubstituteBindings::class
  23.    ], 
  24.      
  25.    'api' => [ 
  26.     'throttle:60,1'
  27.     'bindings'
  28.    ], 
  29.   ]; 

这个核心类继承自他的父类Illuminate\Foundation\Http\Kernel::class,核心类做了很多事情,它会将所有的中间件全部存储到一个指定的数组,方便内核调用及其他类调用。

  1. namespace App\Http; 
  2.    
  3. use App\Api\Middleware\VerifyApiToken; 
  4. use Illuminate\Foundation\Http\Kernel as HttpKernel; 
  5.    
  6. class Kernel extends HttpKernel 

回到起点

Laravel的启动经历了很繁琐的一个过程,这也是Laravel优雅的关键点。

  1. $response = $kernel->handle( 
  2.  $request = Illuminate\Http\Request::capture() 
  3. ); 
  4.  
  5. $response->send(); 
  6.  
  7. $kernel->terminate($request$response); 

将请求传入则完成了整个laravel的启动,至于结果的返回则有开发者自行通过控制器或其他可访问类返回。

Tags: Laravel源码解析 Laravel入口文件

分享到: