【PHP进阶】什么是中间件?(以laravel为例)

分享于:2019-09-06 23:56:27

什么是中间件?


在不同领域,中间件都有不同的定位,我们这里只介绍web后端开发中的中间件。

根据zend-framework中的定义:所谓中间件是指提供在请求和响应之间的,能够截获请求,并在其基础上进行逻辑处理,与此同时能够完成请求的响应或传递到下一个中间件的代码。

前面比较晦涩,看看流程图,以laravel为例演示“删除评论”的请求周期(并非完整的请求周期,只为了让大家容易理解):


20170923115548221.jpg


请求周期


看完流程你会发现,登陆功能放在中间件后,控制器的任务变得清晰多了,只是用来执行核心功能(删除评论)。但是也有人可能会认为:感觉流程变多了,开发起来不是很慢吗?下面来回答这个问题。

为什么需要中间件?


1.不需要中间件的场景

当我们开发一个比较小的外包项目时,我们首要考虑的是如何快速开发完项目并交付,而不是考虑其日后的升级和扩展,业务逻辑也不是很复杂,那么我们完全可以一个控制器(controller)完成所有业务代码,这是没问题的,但是当我们做一个业务逻辑比较复杂的项目呢?

2.需要中间件的场景

业务逻辑比较复杂时,把所有业务代码都写在控制器里就显得不太合适了,因为控制器会非常臃肿,难以维护,这个时候我们就需要对结构进行分层(service辅助controller,actions和Repositories辅助model,这些我会在另外的文章提到)、将cookie操作/用户权限验证等操作写到各自的中间件里,这样我们写出来的项目可维护性就会大大提高。

中间件的执行顺序?


1.中间件为什么会有执行顺序

假设场景:用户删除评论,我们需要验证用户是否登陆,评论删除成功以后需要记录这个业务的操作日志。

执行流程(只考虑核心流程):入口(index.php) > 验证登陆(中间件1) > 记录数据(中间件2) > 业务处理(控制器) > 记录操作日志(中间件3) > 返回响应。

上面为什么会有3个中间件而不是两个中间件呢?答案是一般操作日志的记录一个中间件是无法完成的(可以尝试想想一个中间件怎么实现),我们分别看看各个操作对应的中间件。

验证用户是否登陆:中间件1;记录业务的操作日志:中间件2+中间件3;这3个中间件如果不区分执行顺序,那需求就无法实现了,这就是为什么中间件会有执行顺序。

2.前置中间件&后置中间件

这里提一下什么叫前置中间件跟后置中间件。

前置中间件:应用处理业务请求(controller)之前执行的中间件,上面例子中的中间件1和中间件2就是。

后置中间件:应用处理业务请求(controller)之后执行的中间件,对应的是中间件3。

总结


我们在做小项目的时候不一定需要用到中间件,但是我们需要知道有这个东西,当我们觉得控制器很臃肿时我们可以考虑把用户认证/IP验证/历史记录等操作放到中间件中,以增强可维护性。


来源:https://www.seoxiehui.cn/article-113444-1.html