你知道什么是 AOP 吗?

前言

AOP 的全称为 Aspect Oriented Programming,意思是:面向切面编程。

为什么会有这篇文章?是因为看了 Laravel 中 Pipeline 的设计,发现 Pipeline 就是基于 AOP 思想的一种实现。

说起 AOP,就不得不说起 OOP,它们又是什么关系,有什么区别?

AOP 与 OOP 的区别

OOP 我们都知道,全程为 Object Oriented Programming ,意思是:面向对象编程。

首先我们要知道 AOPOOP 不是相互对立的关系,可以把 AOP 看作是弥补 OOP 的不足,以此之长、补彼之短,两者结合使用效果最佳。

OOP 是针对业务 实体 及其 属性行为 进行 抽象封装 ,这个不难理解,例如:用户模块、订单模块 等。

AOP 是针对业务切面进行提取,它所面对的是处理过程中的某个 步骤阶段 ,以达到逻辑处理过程中各部分之间低耦合性的 隔离效果 ,例如:日志记录、权限验证 等。

举个例子就容易理解了,如果单纯使用 OOP ,需要在日志模块、订单模块中进行权限验证、日志记录怎么办?难道要在每个方法前都加入权限验证、日志记录的代码吗?那么如果需要在每个方法前和方法后都记录日志怎么办?

这时如果使用 AOP,就可以借助代理完成这些重复的操作,就可以不在每个方法前加入权限验证、日志记录的代码,降低各部分之间的耦合。

AOP 能做什么

除了上面说的 权限验证、日志记录,AOP 还可以做 数据加解密、请求响应数据规范 …

只要是和具体的业务无关的,同时又是业务都在关注的,那么都可以通过 AOP 去抽离这些关注点并将其统一维护,提高代码的复用性。

上面的业务关注点是不是有点似曾相识… 其实我们常用的 路由中间件 就是基于 AOP 思想的一种实现。

AOP 的一种实现

举例:Laravel 中的 路由中间件

/**
 * Send the given request through the middleware / router.
 *
 * @param  \Illuminate\Http\Request  $request
 * @return \Illuminate\Http\Response
 */
protected function sendRequestThroughRouter($request)
{
    $this->app->instance('request', $request);

    Facade::clearResolvedInstance('request');

    $this->bootstrap();

    return (new Pipeline($this->app))
                ->send($request)
                ->through($this->app->shouldSkipMiddleware() ? [] : $this->middleware)
                ->then($this->dispatchToRouter());
}

通过上述代码,可以发现需要执行的中间件配置在 through() 方法中,执行后再执行 then 方法。

上述代码用在了 路由中间件 中,当然也可以用在其他地方,比如用到 controller 中,就可以这样写:

// 示例代码

$pipes = [
    LoggingPipeline::class,   // 日志记录
    PermitPipeline::class,    // 权限验证
];

return app(Pipeline::class)
    ->send($request->all())
    ->through($pipes)
    ->then(function ($content) {
        return $content;
    });

上面只是在 Laravel 中的一种实现,当然在 PHP 的其他框架中也有类似的实现,例如:YiiThinkPHP 等。

AOP 只是个思想,当然也有其他语言实现,例如:GolangJava等。

推荐阅读

本作品采用《CC 协议》,转载必须注明作者和本文链接
日拱一卒
《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
讨论数量: 6

一早我就感觉 中间件 的设计像 AOP 思想,现在印证了 :grin:

1周前 评论

oop抽象的是对象, aop抽象的是场景

1周前 评论
陈先生

hyperf: 有人找我?

1周前 评论
Jianne

手动捕捉新亮大佬 :grinning:

1周前 评论
xinliang (楼主) 1周前
Jianne (作者) 1周前

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!