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

Go!PHP面向对象的现代AOP框架(php是面向对象还是面向过程)

ccwgpt 2024-09-14 00:13 55 浏览 0 评论

简介

AOP是一个现代的面向切面的框架,使用简单的PHP,具有丰富的功能,适用于新级别的软件开发。该框架允许在传统的面向对象的PHP代码中解决横切问题,为您的代码提供高效和透明的钩子系统。

特征

  • 为PHP提供动态钩子系统,无需更改原始源代码。
  • 不需要任何PECL扩展(php-aop,runkit,uopz)和DI容器即可工作。
  • 面向切面的方面、连接点和切入点设计。
  • 拦截类中任何公共或受保护方法的执行。
  • 拦截静态方法和final类中方法的执行。
  • 拦截traits中方法的执行。
  • 拦截对对象的公共/受保护属性的访问。
  • 用于静态类初始化的钩子(在类加载到PHP内存之后)。
  • 用于对象初始化的钩子(截取 new 关键字)。
  • 拦截系统PHP函数的调用。
  • 能够通过 Around 类型的通知更改任何方法/函数的返回值。
  • 于在源代码中定义切入点的丰富切入点语法。
  • 使用Xcad进行AOP的本机调试。具有编织方面的代码是完全可读的和原生的。您可以在原始类或方面中放置断点,它将工作(对于调试模式)!
  • 可以与任何现有的PHP框架和库集成(有或没有额外的配置)。
  • 高度优化的生产用途:支持操作码缓存,延迟加载建议和方面,连接点缓存,没有运行时检查切入点,没有运行时注释解析,没有evals和 __call 方法,没有慢速代理和 call_user_func_array() 。快速引导过程(2- 20毫秒)和通知调用。

什么是AOP?

AOP(面向对象编程)是一种处理横切关注点的方法,这些关注点是以“模块化”的方式设计和实现的(也就是说,有适当的封装,没有重复等),然后以简洁和健壮的方式集成到所有相关的执行点中,例如通过声明性或编程性手段。

在AOP术语中,执行点被称为连接点。这些点的集合称为切入点,在连接点之前、之后或“周围”执行的新行为称为通知。你可以在Introduction部分阅读更多关于AOP的内容。

安装

AOP框架可以与composer一起安装。安装非常简单

Step 1 使用composer下载库

请composer下载最新版本的Go!AOP框架及其依赖项,运行以下命令:

composer require goaop/framework

Composer会将框架安装到项目的 vendor/goaop/framework 目录中。

Step 2 创建应用程序切面内核

这个框架的目的是为您的应用程序提供简单的AOP集成。你必须首先为你的应用程序创建 AspectKernel 类。这个类将在一个地方管理应用程序的所有方面。

该框架提供了基类,使创建自己的内核变得更容易。要创建应用程序内核,请扩展抽象类 Go\Core\AspectKernel

<?php
// app/ApplicationAspectKernel.php

use Go\Core\AspectKernel;
use Go\Core\AspectContainer;

/**
 * Application Aspect Kernel
 */
class ApplicationAspectKernel extends AspectKernel
{

    /**
     * Configure an AspectContainer with advisors, aspects and pointcuts
     *
     * @param AspectContainer $container
     *
     * @return void
     */
    protected function configureAop(AspectContainer $container)
    {
    }
}

Step 3 在前端控制器中配置aspect内核

要配置方面内核,请调用内核实例的 init() 方法。

// front-controller, for Symfony2 application it's web/app_dev.php

include __DIR__ . '/vendor/autoload.php'; // use composer

// Initialize an application aspect container
$applicationAspectKernel = ApplicationAspectKernel::getInstance();
$applicationAspectKernel->init([
        'debug'        => true, // use 'false' for production mode
        'appDir'       => __DIR__ . '/..', // Application root directory
        'cacheDir'     => __DIR__ . '/path/to/cache/for/aop', // Cache directory
        // Include paths restricts the directories where aspects should be applied, or empty for all source files
        'includePaths' => [
            __DIR__ . '/../src/'
        ]
]);

Step 4 创建一个方面

方面是AOP哲学的关键元素。走!AOP框架只使用简单的PHP类来声明方面,这使得面向对象的所有特性都可以用于方面类。作为一个例子,让我们截取所有的方法并显示它们的名称:

// Aspect/MonitorAspect.php

namespace Aspect;

use Go\Aop\Aspect;
use Go\Aop\Intercept\FieldAccess;
use Go\Aop\Intercept\MethodInvocation;
use Go\Lang\Annotation\After;
use Go\Lang\Annotation\Before;
use Go\Lang\Annotation\Around;
use Go\Lang\Annotation\Pointcut;

/**
 * Monitor aspect
 */
class MonitorAspect implements Aspect
{

    /**
     * Method that will be called before real method
     *
     * @param MethodInvocation $invocation Invocation
     * @Before("execution(public Example->*(*))")
     */
    public function beforeMethodExecution(MethodInvocation $invocation)
    {
        echo 'Calling Before Interceptor for: ',
            $invocation,
            ' with arguments: ',
            json_encode($invocation->getArguments()),
            "<br>\n";
    }
}

很简单,不是吗?我们在这里声明,我们希望在执行Example类中的所有动态公共方法之前安装一个钩子。这是在注释#0的帮助下完成的#钩子可以是任何类型,你稍后会看到它们。但是我们不改变类Example中的任何代码!我能感受到你的惊讶。

Step 5 在方面内核中注册方面

要注册aspect,只需在内核的 configureAop() 方法中添加它的实例:

// app/ApplicationAspectKernel.php

use Aspect\MonitorAspect;

//...

    protected function configureAop(AspectContainer $container)
    {
        $container->registerAspect(new MonitorAspect());
    }

//...

Step 6 可选配置

默认情况下,Go!AOP使用 Doctrine\Common\Cache\FilesystemCache 来缓存注释。但是,如果您需要使用任何其他缓存引擎进行注释,您可以通过应用程序方面内核的 annotationCache 配置选项配置缓存驱动程序。唯一的要求是缓存驱动程序实现 Doctrine\Common\Cache\Cache 接口。

这在部署到只读文件系统时非常有用。在这种情况下,你可以使用,例如: Doctrine\Common\Cache\ArrayCache 或一些基于内存的缓存驱动程序。

相关推荐

十分钟让你学会LNMP架构负载均衡(impala负载均衡)

业务架构、应用架构、数据架构和技术架构一、几个基本概念1、pv值pv值(pageviews):页面的浏览量概念:一个网站的所有页面,在一天内,被浏览的总次数。(大型网站通常是上千万的级别)2、u...

AGV仓储机器人调度系统架构(agv物流机器人)

系统架构层次划分采用分层模块化设计,分为以下五层:1.1用户接口层功能:提供人机交互界面(Web/桌面端),支持任务下发、实时监控、数据可视化和报警管理。模块:任务管理面板:接收订单(如拣货、...

远程热部署在美团的落地实践(远程热点是什么意思)

Sonic是美团内部研发设计的一款用于热部署的IDEA插件,本文其实现原理及落地的一些技术细节。在阅读本文之前,建议大家先熟悉一下Spring源码、SpringMVC源码、SpringBoot...

springboot搭建xxl-job(分布式任务调度系统)

一、部署xxl-job服务端下载xxl-job源码:https://gitee.com/xuxueli0323/xxl-job二、导入项目、创建xxl_job数据库、修改配置文件为自己的数据库三、启动...

大模型:使用vLLM和Ray分布式部署推理应用

一、vLLM:面向大模型的高效推理框架1.核心特点专为推理优化:专注于大模型(如GPT-3、LLaMA)的高吞吐量、低延迟推理。关键技术:PagedAttention:类似操作系统内存分页管理,将K...

国产开源之光【分布式工作流调度系统】:DolphinScheduler

DolphinScheduler是一个开源的分布式工作流调度系统,旨在帮助用户以可靠、高效和可扩展的方式管理和调度大规模的数据处理工作流。它支持以图形化方式定义和管理工作流,提供了丰富的调度功能和监控...

简单可靠高效的分布式任务队列系统

#记录我的2024#大家好,又见面了,我是GitHub精选君!背景介绍在系统访问量逐渐增大,高并发、分布式系统成为了企业技术架构升级的必由之路。在这样的背景下,异步任务队列扮演着至关重要的角色,...

虚拟服务器之间如何分布式运行?(虚拟服务器部署)

  在云计算和虚拟化技术快速发展的今天,传统“单机单任务”的服务器架构早已难以满足现代业务对高并发、高可用、弹性伸缩和容错容灾的严苛要求。分布式系统应运而生,并成为支撑各类互联网平台、企业信息系统和A...

一文掌握 XXL-Job 的 6 大核心组件

XXL-Job是一个分布式任务调度平台,其核心组件主要包括以下部分,各组件相互协作实现高效的任务调度与管理:1.调度注册中心(RegistryCenter)作用:负责管理调度器(Schedule...

京东大佬问我,SpringBoot中如何做延迟队列?单机与分布式如何做?

京东大佬问我,SpringBoot中如何做延迟队列?单机如何做?分布式如何做呢?并给出案例与代码分析。嗯,用户问的是在SpringBoot中如何实现延迟队列,单机和分布式环境下分别怎么做。这个问题其实...

企业级项目组件选型(一)分布式任务调度平台

官网地址:https://www.xuxueli.com/xxl-job/能力介绍架构图安全性为提升系统安全性,调度中心和执行器进行安全性校验,双方AccessToken匹配才允许通讯;调度中心和执...

python多进程的分布式任务调度应用场景及示例

多进程的分布式任务调度可以应用于以下场景:分布式爬虫:importmultiprocessingimportrequestsdefcrawl(url):response=re...

SpringBoot整合ElasticJob实现分布式任务调度

介绍ElasticJob是面向互联网生态和海量任务的分布式调度解决方案,由两个相互独立的子项目ElasticJob-Lite和ElasticJob-Cloud组成。它通过弹性调度、资源管控、...

分布式可视化 DAG 任务调度系统 Taier 的整体流程分析

Taier作为袋鼠云的开源项目之一,是一个分布式可视化的DAG任务调度系统。旨在降低ETL开发成本,提高大数据平台稳定性,让大数据开发人员可以在Taier直接进行业务逻辑的开发,而不用关...

SpringBoot任务调度:@Scheduled与TaskExecutor全面解析

一、任务调度基础概念1.1什么是任务调度任务调度是指按照预定的时间计划或特定条件自动执行任务的过程。在现代应用开发中,任务调度扮演着至关重要的角色,它使得开发者能够自动化处理周期性任务、定时任务和异...

取消回复欢迎 发表评论: