hasMethod($method)) { //检查在类中特定的方法是否被定义。 $reflectionMethod = $plugin->getMethod($method); //获取类中的方法 if ($reflectionMethod->isStatic()) { //判断其方法是否为静态方法 $items = $reflectionMethod->invoke(null); } else { $pluginInstance = $plugin->newInstance(); //创建类的新实例。给定参数传递给类构造函数。 $items = $reflectionMethod->invoke($pluginInstance); } $menu = array_merge($menu, is_array($items)?$items:[$items]); } } return $menu;}/** * 首先从一堆已定义的类中找到实现Iplugin接口的类 * 然后将其存放在数组中 return * @param string $interfaceName * @return array $plugins */function findPlugins($interfaceName){ $plugins = array(); //返回由已定义类的名字所组成的数组 foreach (get_declared_classes() as $class){ $reflectionClass = new ReflectionClass($class);//获得class的反射对象,包括私有的属性方法 if ($reflectionClass->implementsInterface($interfaceName)) { //检查它是否实现了Iplugin接口 $plugins[] = $reflectionClass; //找到需要反射的类 } } return $plugins;}interface Iplugin{ public static function getName(); //定义接口和静态方法}//实现Iplugin接口class MycoolPugin implements Iplugin { public static function getName(){ return 'MycoolPlugin'; } public 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'=> 'xxxxxxxxx' )); }}$menu = compute('getMenuItems','Iplugin');$articles = compute('getArticles','Iplugin');print_r($menu);echo "
";print_r($articles);echo "
";$name = compute('getName','Iplugin');print_r($name);/* new class和new ReflectionClass的区别是什么 1、new $class() 实例化class对象 2、new ReflectionClass($class) 获得class的反射对象(包含了元数据信息) 区别: 1、new出来的class,你不能访问他的私有属性/方法,但反射可以。 2、反射返回的对象是class的元数据对象(包含class的所有属性/方法的元数据信息),但不是类本身;类似于查到了类的户口档案,但户口档案不是人!*/
实现原理:
先调用get_declared_classes()返回已被定义的类,
然后调用implementsInterface(Stringa $str)方法获取到实现需要获取接口的类名,
然后调用其方法(public,static public)