Reflexionsbasiertes Plug-inArchitektur wird eigentlich nicht als Muster klassifiziert, da es sich eigentlich nicht um eine Vorlage handelt, sondern um eine Reihe von Konzepten, die zur Programmarchitektur kombiniert werden.
Die Plug-in-Methode der Reflection API basiert auf der Bestimmung der Funktion des Programms zur Laufzeit, d. h. sie ermöglicht die Erstellung optionaler Schnittstellenmethoden und erkennt diesen Teil der Schnittstellenmethode beim ersten Mal Nur verwendet. Diese Schnittstellen werden nur verwendet, wenn sie im Plug-in vorhanden sind.
interface IPlugin{ function getMenuItems(); function getArticles(); function getSideBars(); } class Someplugin implelents IPlugin{ public function getMenuItems(){ //没有菜单项 return null; } public function getArticles(){ //没有任何文章 return null; } public function getSidBars(){ //有侧边 return array("sidbarItem'); } } [html] 这种情况并不太合理,因为满足了接口的要求,为大量方法添加了不会用到的函数体,如果在API中有数百个方法,这样是行不通的。 反射API提供了一种解决方法,使用get_ declare d_classes()函数取得当前加载的类,并检测哪个类实现了IPlugin"标记"的方法。 在这里写了一个使用反射查找插件的方法 [code] function findPlugins(){ $plugins=array(); foreach (get_declared_classes() as $class){ $reflectionsClass=new ReflectionClass($class); if($reflectionsClass->implementsInterface('IPlugin')){ $plugins[]=$reflectionsClass; } } return $plugins; }
Bestimmen Sie die Mitglieder der Klasse, die für das Menü verwendet werden
function computerMenu(){ $menu=array(); foreach (findPlugins() as $plugin){ if($plugin->hasMethod('getMenuItems')){ $reflectionMethod=$plugin->getMethod('getMenuItems'); if($reflectionMethod->is Static ()){ $items=$reflectionMethod->invoke(null); }else{ $pluginInstance=$plugin->newInstance(); $items=$reflectionMethod->invoke($pluginInstance); } $menu= array_merge ($menu,$items); } } return $menu; }
Nachdem Sie die Instanz der Klasse erhalten haben, müssen Sie prüfen, ob sie
statischAufrufe erkennen kann die API-Methode, wenn die Methode statisch ist, rufen Sie einfach die Funktion invoke() auf, wie folgt public Mixed invoke(stdclass object, Mixed args=null)
Wenn die Methode andererseits nicht statisch ist, Sie müssen eine Instanz des Plug-Ins abrufen, um diese Methode aufzurufen. Sie müssen eine Instanz der Klasse vom Refectionclass-Objekt abrufen,
ihre newInstance()-Methode aufrufen und dann die invoke()-Methode verwenden, um die zurückzugeben Instanz und übergeben Sie sie.
Bestimmen Sie die Mitglieder der Klasse, die für Artikel und Seiten verwendet werden
function computeArticles(){ $articles=array(); foreach (findPlugins() as $plugin){ if($plugin->hasMethod('getArticles')){ $reflectionMethod=$plugin->getMethod('getArticles'); if($reflectionMethod->isStatic()){ $items=$reflectionMethod->invoke(null); }else{ $pluginInstance=$plugin->newInstance(); $items=$reflectionMethod->invoke($pluginInstance); } $articles=array_merge($articles,$items); } } return $articles; } function computeSidebars(){ $sidebars=array(); foreach (findPlugins() as $plugin){ if($plugin->hasMethod('getSidebars')){ $reflectionMethod=$plugin->getMethod('getSidebars'); if($reflectionMethod->isStatic()){ $items=$reflectionMethod->invoke(null); }else{ $pluginInstance=$plugin->newInstance(); $items=$reflectionMethod->invoke($pluginInstance); } $sidebars=array_merge($sidebars,$items); } } return $sidebars; }
Erstellen Sie ein reflektierendes Plug-In, das optionale Funktionen implementiert
class MyCoolPlugin implements IPlugin{ public static function getName(){return 'MyCoolPlugin';} public static function getMenuItems(){ //菜单项的数字索引数组 return array(array('description'=>'MyCoolPlugin','link'=>'/MyCoolPlugin')); } public static function getArticles(){ //文章的数字索引数组 return array(array('path'=>'/MyCoolPlugin','title'=>'This is a really cool article', 'text'=>'This article is cool because...')); } public static function getSideBars(){ //文章的侧边栏索引数组 return array(array('sideBars'=>'/MyCoolPlugin')); } }
$menu=computeArticles(); $sidebars=computeSidebars(); $articles=computeArticles(); print_r($menu); print_r($sidebars); print_r($articles);
Das obige ist der detaillierte Inhalt vonAusführliche Erläuterung von Plug-In-Beispielen mit Reflection-Technologie in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!