Home >PHP Framework >Laravel >A preliminary understanding of the life cycle in Laravel

A preliminary understanding of the life cycle in Laravel

青灯夜游
青灯夜游forward
2021-09-07 19:49:272347browse

The tutorial column of Laravel will give you a preliminary understanding of the life cycle in Laravel. I hope it will be helpful to friends in need!

A preliminary understanding of the life cycle in Laravel

Life cycle of PHP

PHP running mode

Two types of PHP running The modes are WEB mode and CLI mode.

  • When we type the php command in the terminal, we are using the CLI mode.

  • When using Nginx or another web server as the host to handle an incoming request, the WEB mode is used.

Life cycle

When we request a php file, PHP will undergo 5 stages of life cycle switching in order to complete the request. :

Module initialization (MINIT), that is, calling the extended initialization function specified in php.ini to perform initialization work, such as mysql extension.

Request initialization (RINIT), which is to initialize the symbol table of variable names and variable value contents required to execute this script, such as the $_SESSION variable.

Execute the PHP script.

After the request processing is completed (Request Shutdown), call the RSHUTDOWN method of each module in order, and call the unset function for each variable, such as unset $_SESSION variable.

When closing the module (Module Shutdown), PHP calls the MSHUTDOWN method of each extension. This is the last opportunity for each module to release memory. This means there is no next request.

WEB mode is very similar to CLI (command line) mode. The difference is:

CLI mode will go through a complete 5 cycles each time the script is executed, because there will be no next request; In order to cope with concurrency, the WEB mode may use multi-threading, so life cycles 1 and 5 may only be executed once, and life cycles 2-4 will be repeated when the next request comes, thus saving the overhead caused by system module initialization. It can be seen that the PHP life cycle is very symmetrical. Having said so much, it is to locate where Laravel is running. Yes, Laravel only runs in the third stage:

A preliminary understanding of the life cycle in Laravel

Function

Understand these, you can optimize your Laravel code and have a deeper understanding of Laravel's singleton (single case). At least you know that after each request ends, PHP variables will be unset. Laravel's singleton is only a singleton during a certain request; your static variables in Laravel cannot be shared between multiple requests, because each request It will be unset at the end. Understanding these concepts is the first and most critical step to writing high-quality code. So remember, PHP is a scripting language, and all variables will only take effect in this request and will be reset on the next request, unlike Java static variables that have global effects.

Laravel’s life cycle

Overview

Laravel’s life cycle starts from public\index.php and ends with public\ index.php ends.

A preliminary understanding of the life cycle in Laravel

The following is the entire source code of public\index.php. More specifically, it can be divided into four steps:

1. require __DIR__.'/../bootstrap/autoload.php';

2. $app = require_once __DIR__.'/../bootstrap/app.php';
   $kernel = $app->make(Illuminate\Contracts\Http\Kernel::class);

3. $response = $kernel->handle(
      $request = Illuminate\Http\Request::capture()
   );
   $response->send();

4. $kernel->terminate($request, $response);

The following is a detailed explanation of the four steps. yes: Composer automatically loads the required classes

file to load the auto-loading settings generated by composer, including all your composer require dependencies.

Generate container Container, Application instance, and register core components (HttpKernel, ConsoleKernel, ExceptionHandler) with the container (corresponding to code 2, the container is very important, and will be explained in detail later).

Process the request, generate and send the response (corresponding to code 3, it is no exaggeration to say that 99% of your code runs in this small handle method).

The request ends and a callback is performed (corresponding to code 4, do you remember the terminating middleware? Yes, it is called back here).

A preliminary understanding of the life cycle in Laravel

We might as well go into more detail:

Step 1: Register and load the class loader automatically generated by composer It is to load and initialize third-party dependencies.

Step 2: Generate container Container And registering core components with the container is to obtain the Laravel application instance from the bootstrap/app.php script.

The third step: This step is the focus, processing the request and generating a response. Requests are sent to the HTTP core or the Console core, depending on the type of request coming into the application.

Depends on whether the request is through the browser or the console. Here we mainly request through the browser. The logic of handle processing, the iconic method of the HTTP kernel, is quite simple: get a Request, return a Response, imagine the kernel as a big black box representing the entire application, input an HTTP request, and return an HTTP response.

首先 Bootstrap 检测环境,加载 bootstrapper数组中的一些配置

HTTP 内核继承自 Illuminate\Foundation\Http\Kernel 类,该类定义了一个 bootstrappers 数组,这个数组中的类在请求被执行前运行,这些 bootstrappers 配置了错误处理、日志、检测应用环境以及其它在请求被处理前需要执行的任务。

protected $bootstrappers = [
    //注册系统环境配置 (.env)
    'Illuminate\Foundation\Bootstrap\DetectEnvironment',
    //注册系统配置(config)
    'Illuminate\Foundation\Bootstrap\LoadConfiguration',
    //注册日志配置
    'Illuminate\Foundation\Bootstrap\ConfigureLogging',
    //注册异常处理
    'Illuminate\Foundation\Bootstrap\HandleExceptions',
    //注册服务容器的门面,Facade 是个提供从容器访问对象的类。
    'Illuminate\Foundation\Bootstrap\RegisterFacades',
    //注册服务提供者
    'Illuminate\Foundation\Bootstrap\RegisterProviders',
    //注册服务提供者 `boot`
    'Illuminate\Foundation\Bootstrap\BootProviders',
];

注意顺序:

Facades 先于ServiceProviders,Facades也是重点,后面说,这里简单提一下,注册 Facades 就是注册 config\app.php中的aliases 数组,你使用的很多类,如Auth,Cache,DB等等都是Facades;而ServiceProviders的register方法永远先于boot方法执行,以免产生boot方法依赖某个实例而该实例还未注册的现象。HTTP 内核还定义了一系列所有请求在处理前需要经过的 HTTP 中间件,这些中间件处理 HTTP 会话的读写、判断应用是否处于维护模式、验证 CSRF 令牌等等。

第一堵墙,全局中间件,默认为 CheckForMaintenanceMode

在Laravel基础的服务启动之后,就要把请求传递给路由了。路由器将会分发请求到路由或控制器,同时运行所有路由指定的中间件。

传递方式: 传递给路由是通过 Pipeline(管道)来传递的,但是Pipeline有一堵墙,在传递给路由之前所有请求都要经过,这堵墙定义在app\Http\Kernel.php中的$middleware数组中,没错就是中间件,默认只有一个CheckForMaintenanceMode中间件,用来检测你的网站是否暂时关闭。这是一个全局中间件,所有请求都要经过,你也可以添加自己的全局中间件。

然后遍历所有注册的路由,找到最先符合的第一个路由

然后遍历所有注册的路由,找到最先符合的第一个路由,

第二堵墙,通过该路由的中间件(组)

经过该路由中间件,进入到控制器或者闭包函数,执行你的具体逻辑代码。

所以,当请求到达你写的代码之前,Laravel已经做了大量工作,请求也经过了千难万险,那些不符合或者恶意的的请求已被Laravel隔离在外。

A preliminary understanding of the life cycle in Laravel

原文地址:https://juejin.cn/post/6992208648575385607

作者:卡二条

相关推荐:最新的五个Laravel视频教程

The above is the detailed content of A preliminary understanding of the life cycle in Laravel. For more information, please follow other related articles on the PHP Chinese website!

Statement:
This article is reproduced at:掘金--卡二条. If there is any infringement, please contact admin@php.cn delete