이 글은 주로 Hook 메커니즘을 구현하는 방법을 소개합니다. Hook 메커니즘의 원리와 구현 과정을 자세히 소개합니다. 관심 있는 분들은 자세히 알아보세요. 최근에 PHP 프레임워크에서 프로젝트를 확장하기 위해 이 메커니즘을 사용하는 것을 보았으니 살펴보겠습니다.
소위 후크 메커니즘은 Windows 프로그래밍에서 널리 사용되는 기술입니다. 주요 아이디어는 기능을 추가할 수 있는 후크를 미리 묻어 두는 것입니다. 이 후크는 실제적인 의미가 없습니다. 이 위치에 로직을 다시 수정하거나 추가해야 할 경우 확장된 클래스나 메소드를 마운트하면 됩니다. 이 점.
프로젝트 코드에서 확장이 필요하다고 생각되는 위치(아직 확장되지 않음)와 필요할 때 후크 기능을 배치합니다. 확장하려면 구현해야 하는 클래스와 함수를 마운트하세요. 이 후크를 사용하면 확장이 가능합니다.
이 아이디어는 다소 일반적으로 들리지만 온라인 구현 예를 살펴보겠습니다.
전체 플러그인 메커니즘은 세 부분으로 구성됩니다.1.hook 플러그인 관리자 클래스: 이는 핵심 파일이며 애플리케이션 전역 전역 객체입니다. 여기에는 세 가지 주요 책임이 있습니다.
1> 등록된 모든 플러그인을 모니터링하고 이러한 플러그인 개체를 인스턴스화합니다.
2>모든 플러그인을 등록합니다.
3>hook 조건이 만족되면 해당 객체 메소드가 트리거됩니다.
2. 플러그인 기능 구현: 이는 대부분 타사 개발자가 수행하지만 당사의 (관리자 클래스 정의) 규칙을 따라야 합니다. 이 규칙은 플러그인 메커니즘에 따라 규정되며 플러그인에 따라 다릅니다. 메커니즘에서.
3. 플러그인 트리거링: 즉, 후크의 트리거링 조건입니다. 이는 이 후크를 트리거하기 위해 플러그인을 호출해야 하는 곳에 배치된 작은 코드 조각입니다.
-----------------------다른 분들의 해결 방법을 살펴보세요-------- ---------
첫 번째는 플러그인 관리자 클래스인 PluginManager입니다. 이 클래스는 전역 참조에 배치되어야 하며 다음을 수행하는 모든 애플리케이션에서 사용되어야 합니다. 플러그인을 사용해야 하며, 우선 로딩이 필요합니다.
<?php /** * * 插件机制的实现核心类 */ class PluginManager { /** * 监听已注册的插件 * * @access private * @var array */ private $_listeners = array(); /** * 构造函数 * * @access public * @return void */ public function __construct() { #这里$plugin数组包含我们获取已经由用户激活的插件信息 #为演示方便,我们假定$plugin中至少包含 #$plugin = array( # 'name' => '插件名称', # 'directory'=>'插件安装目录' #); $plugins = get_active_plugins();#这个函数请自行实现 if($plugins) { foreach($plugins as $plugin) {//假定每个插件文件夹中包含一个actions.php文件,它是插件的具体实现 if (@file_exists(STPATH .'plugins/'.$plugin['directory'].'/actions.php')) { include_once(STPATH .'plugins/'.$plugin['directory'].'/actions.php'); $class = $plugin['name'].'_actions'; if (class_exists($class)) { //初始化所有插件 new $class($this); } } } } #此处做些日志记录方面的东西 } /** * 注册需要监听的插件方法(钩子) * * @param string $hook * @param object $reference * @param string $method */ function register($hook, &$reference, $method) { //获取插件要实现的方法 $key = get_class($reference).'->'.$method; //将插件的引用连同方法push进监听数组中 $this->_listeners[$hook][$key] = array(&$reference, $method); #此处做些日志记录方面的东西 } /** * 触发一个钩子 * * @param string $hook 钩子的名称 * @param mixed $data 钩子的入参 * @return mixed */ function trigger($hook, $data='') { $result = ''; //查看要实现的钩子,是否在监听数组之中 if (isset($this->_listeners[$hook]) && is_array($this->_listeners[$hook]) && count($this->_listeners[$hook]) > 0) { // 循环调用开始 foreach ($this->_listeners[$hook] as $listener) { // 取出插件对象的引用和方法 $class =& $listener[0]; $method = $listener[1]; if(method_exists($class,$method)) { // 动态调用插件的方法 $result .= $class->$method($data); } } } #此处做些日志记录方面的东西 return $result; } }
다음 단계는 간단한 플러그인인 DEMO_actions를 구현하는 것입니다. 문장 출력을 위한 간단한 Hello World 플러그인입니다. 실제 상황에서 say_hello에는 데이터베이스에 대한 작업이나 기타 특정 논리가 포함될 수 있습니다.
<?php /** * 这是一个Hello World简单插件的实现 */ /** *需要注意的几个默认规则: * 1. 本插件类的文件名必须是action * 2. 插件类的名称必须是{插件名_actions} */ class DEMO_actions { //解析函数的参数是pluginManager的引用 function __construct(&$pluginManager) { //注册这个插件 //第一个参数是钩子的名称 //第二个参数是pluginManager的引用 //第三个是插件所执行的方法 $pluginManager->register('demo', $this, 'say_hello'); } function say_hello() { echo 'Hello World'; } }
다음 단계에서는 플러그인 호출이 트리거됩니다. 예를 들어 내 블로그 Index.php의 홈페이지에 say_hello를 추가하려면 index.php의 어딘가에 다음을 작성합니다.
$pluginManager->trigger('demo','');첫 번째 매개변수는 Hook의 이름을 나타내고, 두 번째 매개변수는 플러그인의 해당 메소드의 입력 매개변수입니다. 이 예시에서는 입력 매개변수가 없으므로 비어 있습니다. 이러한 예는 기본적으로 "후크" 플러그인 메커니즘의 구현 방법과 논리를 명확하게 표현합니다. 관련 권장사항:
Framework Thinkphp5 단순 구현 동작 Hook
PHP로 작성된 웹후크는 git을 실행할 수 없습니다.
PHP가 Hook 메커니즘을 구현하는 방법에 대한 자세한 설명
위 내용은 PHP에서 후크 메커니즘을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!