相思资源网 Design By www.200059.com

最近在开发过程中需要获取某个类方法的参数数量、名称及参数顺序,好根据参数的名称来从$_GET里取值。

如方法原型为test($uid,$score), 那么我就知道需要需要从$_GET取
复制代码 代码如下:
$uid = $_GET['uid'];

$score = $_GET['score'];

然后调用方法$obj->test($uid,$score)

当然前提是约定好了参数名称和get方法传值变量名一致。

采用PHP的反射API,获得函数参数名称和参数默认值的方法如下:
复制代码 代码如下:
<"\n"; 
    if ($param->isOptional()) { 
        echo 'Default value: ' . $param->getDefaultValue(),"\n"; 
    } 

下面是PHP反射API的介绍:

1、用途:
该扩展分析php程序,导出或提取出关于类、方法、属性、参数等的详细信息,包括注释。
Reflection可以说是对php库函数:“Classes/Objects 类/对象函数”的一个扩展。
主要用在通过程序检测现有php程序内部关于类、方法等信息,并做出处理。

2、API概览:
复制代码 代码如下:
class Reflection { } 
interface Reflector { } 
class ReflectionException extends Exception { } 
class ReflectionFunction implements Reflector { } 
class ReflectionParameter implements Reflector { } 
class ReflectionMethod extends ReflectionFunction { } 
class ReflectionClass implements Reflector { } 
class ReflectionObject extends ReflectionClass { } 
class ReflectionProperty implements Reflector { } 
class ReflectionExtension implements Reflector { } 

3、详细说明:(例子详见php手册)
复制代码 代码如下:
①Reflection类 
<?php 
class Reflection 

public static mixed export(Reflector r [,bool return]) 
//导出一个类或方法的详细信息 
public static array getModifierNames(int modifiers) 
//取得修饰符的名字 

?> 
 
②ReflectionException类 
 
该类继承标准类,没特殊方法和属性。 
 
③ReflectionFunction类 
<?php 
class ReflectionFunction implements Reflector 

final private __clone() 
public object __construct(string name) 
public string __toString() 
public static string export() 
//导出该函数的详细信息 
public string getName() 
//取得函数名 
public bool isInternal() 
//测试是否为系统内部函数 
public bool isUserDefined() 
//测试是否为用户自定义函数 
public string getFileName() 
//取得文件名,包括路径名 
public int getStartLine() 
//取得定义函数的起始行 
public int getEndLine() 
//取得定义函数的结束行 
public string getDocComment() 
//取得函数的注释 
public array getStaticVariables() 
//取得静态变量 
public mixed invoke(mixed* args) 
//调用该函数,通过参数列表传参数 
public mixed invokeArgs(array args) 
//调用该函数,通过数组传参数 
public bool returnsReference() 
//测试该函数是否返回引用 
public ReflectionParameter[] getParameters() 
//取得该方法所需的参数,返回值为对象数组 
public int getNumberOfParameters() 
//取得该方法所需的参数个数 
public int getNumberOfRequiredParameters() 
//取得该方法所需的参数个数 

?> 
 
④ReflectionParameter类: 
<?php 
class ReflectionParameter implements Reflector 

final private __clone() 
public object __construct(string name) 
public string __toString() 
public static string export() 
//导出该参数的详细信息 
public string getName() 
//取得参数名 
public bool isPassedByReference() 
//测试该参数是否通过引用传递参数 
public ReflectionClass getClass() 
//若该参数为对象,返回该对象的类名 
public bool isArray() 
//测试该参数是否为数组类型 
public bool allowsNull() 
//测试该参数是否允许为空 
public bool isOptional() 
//测试该参数是否为可选的,当有默认参数时可选 
public bool isDefaultValueAvailable() 
//测试该参数是否为默认参数 
public mixed getDefaultValue() 
//取得该参数的默认值 

?> 
 
⑤ReflectionClass类: 
<?php 
class ReflectionClass implements Reflector 

final private __clone() 
public object __construct(string name) 
public string __toString() 
public static string export() 
//导出该类的详细信息 
public string getName() 
//取得类名或接口名 
public bool isInternal() 
//测试该类是否为系统内部类 
public bool isUserDefined() 
//测试该类是否为用户自定义类 
public bool isInstantiable() 
//测试该类是否被实例化过 
public bool hasConstant(string name) 
//测试该类是否有特定的常量 
public bool hasMethod(string name) 
//测试该类是否有特定的方法 
public bool hasProperty(string name) 
//测试该类是否有特定的属性 
public string getFileName() 
//取得定义该类的文件名,包括路径名 
public int getStartLine() 
//取得定义该类的开始行 
public int getEndLine() 
//取得定义该类的结束行 
public string getDocComment() 
//取得该类的注释 
public ReflectionMethod getConstructor() 
//取得该类的构造函数信息 
public ReflectionMethod getMethod(string name) 
//取得该类的某个特定的方法信息 
public ReflectionMethod[] getMethods() 
//取得该类的所有的方法信息 
public ReflectionProperty getProperty(string name) 
//取得某个特定的属性信息 
public ReflectionProperty[] getProperties() 
//取得该类的所有属性信息 
public array getConstants() 
//取得该类所有常量信息 
public mixed getConstant(string name) 
//取得该类特定常量信息 
public ReflectionClass[] getInterfaces() 
//取得接口类信息 
public bool isInterface() 
//测试该类是否为接口 
public bool isAbstract() 
//测试该类是否为抽象类 
public bool isFinal() 
//测试该类是否声明为final 
public int getModifiers() 
//取得该类的修饰符,返回值类型可能是个资源类型 
//通过Reflection::getModifierNames($class->getModifiers())进一步读取 
public bool isInstance(stdclass object) 
//测试传入的对象是否为该类的一个实例 
public stdclass newInstance(mixed* args) 
//创建该类实例 
public ReflectionClass getParentClass() 
//取得父类 
public bool isSubclassOf(ReflectionClass class) 
//测试传入的类是否为该类的父类 
public array getStaticProperties() 
//取得该类的所有静态属性 
public mixed getStaticPropertyValue(string name [, mixed default]) 
//取得该类的静态属性值,若private,则不可访问 
public void setStaticPropertyValue(string name, mixed value) 
//设置该类的静态属性值,若private,则不可访问,有悖封装原则 
public array getDefaultProperties() 
//取得该类的属性信息,不含静态属性 
public bool isIterateable() 
public bool implementsInterface(string name) 
//测试是否实现了某个特定接口 
public ReflectionExtension getExtension() 
public string getExtensionName() 

?> 
 
⑥ReflectionMethod类: 
<?php 
class ReflectionMethod extends ReflectionFunction 

public __construct(mixed class, string name) 
public string __toString() 
public static string export() 
//导出该方法的信息 
public mixed invoke(stdclass object, mixed* args) 
//调用该方法 
public mixed invokeArgs(stdclass object, array args) 
//调用该方法,传多参数 
public bool isFinal() 
//测试该方法是否为final 
public bool isAbstract() 
//测试该方法是否为abstract 
public bool isPublic() 
//测试该方法是否为public 
public bool isPrivate() 
//测试该方法是否为private 
public bool isProtected() 
//测试该方法是否为protected 
public bool isStatic() 
//测试该方法是否为static 
public bool isConstructor() 
//测试该方法是否为构造函数 
public bool isDestructor() 
//测试该方法是否为析构函数 
public int getModifiers() 
//取得该方法的修饰符 
public ReflectionClass getDeclaringClass() 
//取得该方法所属的类 
// Inherited from ReflectionFunction 
final private __clone() 
public string getName() 
public bool isInternal() 
public bool isUserDefined() 
public string getFileName() 
public int getStartLine() 
public int getEndLine() 
public string getDocComment() 
public array getStaticVariables() 
public bool returnsReference() 
public ReflectionParameter[] getParameters() 
public int getNumberOfParameters() 
public int getNumberOfRequiredParameters() 

?> 
 
⑦ReflectionProperty类: 
<?php 
class ReflectionProperty implements Reflector 

final private __clone() 
public __construct(mixed class, string name) 
public string __toString() 
public static string export() 
//导出该属性的详细信息 
public string getName() 
//取得该属性名 
public bool isPublic() 
//测试该属性名是否为public 
public bool isPrivate() 
//测试该属性名是否为private 
public bool isProtected() 
//测试该属性名是否为protected 
public bool isStatic() 
//测试该属性名是否为static 
public bool isDefault() 
public int getModifiers() 
//取得修饰符 
public mixed getValue(stdclass object) 
//取得该属性值 
public void setValue(stdclass object, mixed value) 
//设置该属性值 
public ReflectionClass getDeclaringClass() 
//取得定义该属性的类 
public string getDocComment() 
//取得该属性的注释 

?> 
 
⑧ReflectionExtension类 
<?php 
class ReflectionExtension implements Reflector { 
final private __clone() 
public __construct(string name) 
public string __toString() 
 
public static string export() 
//导出该扩展的所有信息 
public string getName() 
//取得该扩展的名字 
public string getVersion() 
//取得该扩展的版本 
public ReflectionFunction[] getFunctions() 
//取得该扩展的所有函数 
public array getConstants() 
//取得该扩展的所有常量 
public array getINIEntries() 
//取得与该扩展相关的,在php.ini中的指令信息 
public ReflectionClass[] getClasses() 
public array getClassNames() 

?> 

标签:
PHP反射

相思资源网 Design By www.200059.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
相思资源网 Design By www.200059.com

评论“PHP反射使用实例和PHP反射API的中文说明”

暂无PHP反射使用实例和PHP反射API的中文说明的评论...

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。