百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

易之道:Yii2.0前后端分离开发实战 - 3.2入口脚本和请求生命周期

ccwgpt 2024-09-15 15:11 33 浏览 0 评论

入口脚本和请求生命周期

每个应用的入口文件 index.php 都位于应用的 web 目录下,首先来看看前台 frontend 的入口 index.php 文件的内容:

<?php
defined('YII_DEBUG') or define('YII_DEBUG', true);
defined('YII_ENV') or define('YII_ENV', 'dev');
require __DIR__ . '/../../vendor/autoload.php';
require __DIR__ . '/../../vendor/yiisoft/yii2/Yii.php';
require __DIR__ . '/../../common/config/bootstrap.php';
require __DIR__ . '/../config/bootstrap.php';
$config = yii\helpers\ArrayHelper::merge(
 require __DIR__ . '/../../common/config/main.php',
 require __DIR__ . '/../../common/config/main-local.php',
 require __DIR__ . '/../config/main.php',
 require __DIR__ . '/../config/main-local.php'
);
(new yii\web\Application($config))->run();

前两个 define 语句,定义了当前应用的运行模式和环境。

定义当前应用调试模式状态:true 开户调试模式,false 关闭调试模式;

defined('YII_DEBUG') or define('YII_DEBUG', true);//如果 YII_DEBUG 未定义,那么定义它为 true

定义当前应用的运行环境:dev 开发环境,prod 生产环境,test 测试环境;

defined('YII_ENV') or define('YII_ENV', 'dev');//如果 YII_ENV 未定义,那么定义它为 dev

环境与模式的作用不同。环境在代码中主要是影响配置文件。 YII_ENV 的 devprod test 三种环境, 会分别使 YII_ENV_DEV YII_ENV_PROD YII_ENV_TEST 的值为 true 。 在应用的配置文件中,特别是在相同的一个配置文件中,可以对不同环境做出不同的配置。

比如,你希望在开发环境下,前台应用启用调试工作条等,那么,可以这么做(frontend/config/main-local.php):

<?php
$config = [
 ...
];
if (!YII_ENV_TEST) {
 // 以下配置在非 test 环境下生效,即 YII_ENV !== 'test' 时
 $config['bootstrap'][] = 'debug';
 $config['modules']['debug'] = [
 'class' => 'yii\debug\Module',
 ];
 $config['bootstrap'][] = 'gii';
 $config['modules']['gii'] = [
 'class' => 'yii\gii\Module',
 ];
}
return $config;

引入Yii框架

require __DIR__ . '/../../vendor/autoload.php';
require __DIR__ . '/../../vendor/yiisoft/yii2/Yii.php';
require __DIR__ . '/../../common/config/bootstrap.php';
require __DIR__ . '/../config/bootstrap.php';
  • __DIR__ 表示当前 index.php 所在的目录
  • /../../vendor/ 即根目录下的 vendor 目录
  • /../../common/ 即根目录下的 common 目录
  • /../config/ 即当前应用 frontend 目录下的 config 目录

第一个 require 引入了 verndor 目录下的 autoload.php,这个是composer的类自动加载机制注册文件。引入这个文件后,可以使用composer的类自动加载功能。

第二个 require 引入了 vendor 目录下面的 yiisoft/yii2/Yii.php,这是 Yii框架核心文件。 引入了这个类文件后,才能使用 Yii 的提供的各种功能,比如 Yii::setAlias(),Yii::$app 之类。

第三个 require 引入了 common 目录下面的 config/bootstrap.php, 这个文件主要用于执行一些 Yii 应用引导的代码,比如定义一系列的路径别名:

<?php
Yii::setAlias('@common', dirname(__DIR__));
Yii::setAlias('@frontend', dirname(dirname(__DIR__)) . '/frontend');
Yii::setAlias('@backend', dirname(dirname(__DIR__)) . '/backend');
Yii::setAlias('@console', dirname(dirname(__DIR__)) . '/console');

这是默认安装后定义好的 common frontend backend console vendor 5个路径别名,如果你要新增一个 api 应用目录, 可以在这个文件里面加一行:

Yii::setAlias('@api', dirname(dirname(__DIR__)) . '/api');

第四个 require 引入了 frontend 目录下面的 config/bootstrap.php。 作用与上面第三个类似,只是其中的代码仅适用于当前应用(frontend)。 而第三个require中的,是适应于全部应用(公共的)。

接着调用了Yii的助手类 yii\helpers\ArrayHelper 的函数 merge,它的作用在于合并参数所指定的各个数组,后面的数组会把前面数组中相同下标的元素覆盖掉。

$config = yii\helpers\ArrayHelper::merge(
 require __DIR__ . '/../../common/config/main.php',
 require __DIR__ . '/../../common/config/main-local.php',
 require __DIR__ . '/../config/main.php',
 require __DIR__ . '/../config/main-local.php'
);

公共应用 common 下的2个配置文件,和当前应用 frontend 下的2个配置文件,在优先顺序上,当前应用的配置覆盖公共应用的配置。同时,带有 -local 的配置文件在后,所以,本地配置文件覆盖团队配置文件。最后把合并好的配置数组 $config 作为Yii框架web应用的初始化参数,创建了一个web应用实例,这时,Yii就跑起来了:

(new yii\web\Application($config))->run();

Yii框架给我们提供了两种应用:web应用 yii\web\Application 和 控制台应用 yii\console\Application;web应用处理网页请求,控制台应用处理 shell cmd命令式交互的请求。 控制台应用入口是根目录下的 yii 文件:

#!/usr/bin/env php
<?php
/**
 * Yii console bootstrap file.
 */
defined('YII_DEBUG') or define('YII_DEBUG', true);
defined('YII_ENV') or define('YII_ENV', 'dev');
require __DIR__ . '/vendor/autoload.php';
require __DIR__ . '/vendor/yiisoft/yii2/Yii.php';
require __DIR__ . '/common/config/bootstrap.php';
require __DIR__ . '/console/config/bootstrap.php';
$config = yii\helpers\ArrayHelper::merge(
 require __DIR__ . '/common/config/main.php',
 require __DIR__ . '/common/config/main-local.php',
 require __DIR__ . '/console/config/main.php',
 require __DIR__ . '/console/config/main-local.php'
);
$application = new yii\console\Application($config);
$exitCode = $application->run();
exit($exitCode);

对于Windows系统而言,yii 文件无法直接运行。所以,细心的Yii为我们准备了一个 yii.bat 文件,这个文件会以 php yii 形式调用PHP来运行入口脚本。

生命周期

每一次 Yii 应用开始处理 HTTP 请求时,它都会进行一个近似的流程。

  • 用户提交指向入口脚本 web/index.php 的请求。
  • 入口脚本会加载 配置数组 并创建一个 应用 实例用于处理该请求。
  • 应用会通过 request(请求) 应用组件 解析被请求的 路由。
  • 应用创建一个 controller(控制器) 实例具体处理请求。
  • 控制器会创建一个 action(动作) 实例并为该动作执行相关的 Filters(访问过滤器)。
  • 如果任何一个过滤器验证失败,该动作会被取消。
  • 如果全部的过滤器都通过,该动作就会被执行。
  • 动作会加载一个 数据模型,一般是从数据库中加载。
  • 动作会渲染一个 View(视图),并为其提供所需的数据模型。
  • 渲染得到的结果会返回给 response(响应) 应用组件。
  • 响应组件会把渲染结果发回给用户的浏览器。

相关推荐

NestJS入门教程系列一

介绍Nest(NestJS)是用于构建高效,可扩展的Node.js服务器端应用程序的框架。它使用渐进式JavaScript,内置并完全支持TypeScript(但开发人员仍然能够使用JavaScrip...

【推荐】一个网盘资源搜索与转存工具,支持移动端与PC端!

如果您对源码&技术感兴趣,请点赞+收藏+转发+关注,大家的支持是我分享最大的动力!!!项目介绍CloudSaver是一个基于Vue3和Express的网盘资源搜索与转存开源实用工具。它支持...

Appium原理精讲

目前使用Appium新版本和旧版本的企业数目都很多,而两个版本的安装过程和api的使用又有较大的区别。但是无论表面上的东东如何变化,内部原理都是一样的。在这里我给大家介绍一下appium的核心,增进大...

Kubernetes最小部署单元Pod

一、Kubernetes与Pod简介在当今云计算和容器化技术盛行的时代,Kubernetes已然成为容器编排领域的中流砥柱。它是一个开源的容器编排平台,由Google基于其内部使用的Bo...

最常用的四种跨域解决方案

前置知识什么是跨域?浏览器发送的请求地址(URL)与所在页面的地址不同(端口/协议/域名其一不同)。简言之,浏览器发出的请求url,与其所在页面的url不一样。此时,同源策略会让浏览器拒收服务器...

Bolt.New —— 全栈AI Web自动编程

Bolt.New是由StackBlitz公司推出的,全栈AI工具,代码编辑、运行、部署,通通一站式搞定。它使用WebContainers技术,无需任何本地安装或配置,在浏览器中,就可以运行完整的No...

Nodejs Express新手教程&amp;高手进阶

NodejsExpress新手教程&高手进阶Express是一个NodeJS平台的框架,主要用于构于Web服务器项目。本文将通过示例介绍适合新手入门的Express基础使用,以及高手进阶知识,如:c...

Express.js 创建Node.js Web应用

Express.js是一个基于Node.js的Web应用框架,框架的设计目的是构建应用的架构和简化应用的开发。框架会解决一些通用的问题,在Express.js中,Express框架会处理如:中间件、代...

JavaScript 的 Express.js 功能及应用场景详解

Express.js是一个基于Node.js的轻量级Web应用框架,主要用于快速构建服务器端应用和API。它的核心功能包括以下关键点:1.路由管理URL路径与HTTP方法映射:通过...

nodejs的express4文件下载

在nodejs的express框架中,下载变得非常简单,就一个方法,res.download()首先express命令行生成项目基本框架:不会的看这里:http://blog.csdn.net/zz...

Express 系列:快速生成一个项目

系列预告本系列将以一个项目入手结合相关技术细节来带领大家一起学习Express这个基于Node.js的后端框架。本文首先将介绍:如何快速的生成一个具有一定结构的Express项目。Express项目结...

nodejs的express自动生成项目框架

nodejs版本为:4.X,express版本为4.X1.全局安装2个模块express、express-generator在命令行输入:npminstall-gexpressnpminsta...

express开发(一)简介与搭建

上周末去了趟上海书城,不愧是上海数得上号的书城,流行的科技书应有尽有,话不多说直接上图。最经典的C语言O(∩_∩)O最流行的java(づ ̄3 ̄)づ超酷的R语言/(ㄒoㄒ)/~~然而,身为一个坚定的前...

Vue+Echarts可视化大屏系统后端框架搭建(附代码)

各位同学,大家好。上节课,前面我们讲解了Vue+Echarts前端部分的设计方法。这节课程,我们开始讲解使用Express进行后端设计的方法。01项目相关理论介绍什么是expressExpress是...

Shopify电商API接口开发

Shopify电商API接口开发上线流程主要包括以下步骤。北京木奇移动技术有限公司,专业的软件外包开发公司,欢迎洽谈合作。前期准备-注册Shopify账号:在Shopify官网注册,用于后续开发测试...

取消回复欢迎 发表评论: