一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

在PHP中使用反射技術的架構插件使用說明

反射API的插件方法是基于在運行時決定程序的功能來實現的,也就是說,它允許創建可選的接口方法,并在首次使用時檢測到這部分接口方法,只有在插件中存在這部分接口的情況下,它們才會被用到.
假設擁有這樣的接口
復制代碼 代碼如下:
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_declared_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;
}

為了為了確定類是否實現了單個方法,可以使用REfectionClass類的hasMethod()方法。
確定用于菜單的類的成員
復制代碼 代碼如下:
function computerMenu(){
$menu=array();
foreach (findPlugins() as $plugin){
if($plugin->hasMethod('getMenuItems')){
$reflectionMethod=$plugin->getMethod('getMenuItems');
if($reflectionMethod->isStatic()){
$items=$reflectionMethod->invoke(null);
}else{
$pluginInstance=$plugin->newInstance();
$items=$reflectionMethod->invoke($pluginInstance);
}
$menu=array_merge($menu,$items);
}
}
return $menu;
}

得到類的實例后,需要檢測是否能夠靜態檢測調用API方法,如果方法是靜態的,只需要調用 invoke()函數,
如下 public mixed invoke(stdclass object,mixed args=null)
另一方面,如果方法不是靜態的,需要取得插件的一個實例來調用這個方法,要從Refectionclass對象取得類的一個實例,
調用 它的newInstance()方法,然后再使用invoke()方法,返回實例傳入就可以。
確定用于文章和側邊的類的成員
復制代碼 代碼如下:
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;
}

創建一個實現了可選特性的反射式插件
復制代碼 代碼如下:
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);

php技術在PHP中使用反射技術的架構插件使用說明,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 欧美日韩亚洲精品国产色 | 综合亚洲一区二区三区 | 又色又爽又黄的视频女女高清 | 国产高清自拍一区 | 国产精品天天影视久久综合网 | 最近最新中文字幕在线第一页 | fefe66免费毛片你懂的 | 91亚洲国产成人久久精品网站 | 美女黄视频在线 | 久久全国免费久久青青小草 | 国产精品久久久久久久专区 | 色婷亚洲 | 色综合天天综合网国产成人 | 中文字幕 亚洲精品 第1页 | 亚洲欧美激情视频 | 黄色视屏在线播放 | 丁香六月婷婷精品免费观看 | 在线播放亚洲精品富二代91 | 一区二区视频在线播放 | 国产成人亚洲精品91专区手机 | 亚洲精品第一页中文字幕 | 激情视频网址 | 国产精品亚洲综合网站 | 国产精品自拍第一页 | 亚洲影视在线 | 国产免费观看视频 | 91综合国产 | 国产一二三四2022精字窝 | 国产一区二区三区在线观看视频 | 国产欧美一区二区精品性色 | 国产一区二区三区在线 | chinese在线播放91国内 | 亚洲欧美日本在线 | 色多多入口| 黄色网页在线 | 亚洲一区二区在线免费观看 | 中文字幕第二一区 | 亚洲一区二区视频 | 亚洲国产成人久久综合野外 | 黄色小视频在线播放 | 国内精品91久久久久 |