我有这个:
$classname
$propertyname
我想从该类中获取该属性,问题是该属性是静态的,我不知道该怎么做。
如果该属性不是静态的,则可能是:
$classname->$propertyname;
如果属性是一个方法,我本可以使用call_user_function
call_user_func(array($classname, $propertyname));
但就我而言,我只是迷路了。但是,我希望这是可能的。有了PHP所具有的数千个功能,他最好为此也有所准备。也许我缺少什么?
谢谢!
编辑:
如果您使用的是PHP 5.3.0或更高版本,则可以使用以下代码:
$classname::$$propertyname;
不幸的是,如果您使用的版本低于5.3.0,那么您 将无法使用eval()(get_class_vars()如果该值是动态的,则将无法使用)。
eval()
get_class_vars()
$value = eval($classname.'::$'.$propertyname.';');
编辑: 我刚刚说过get_class_vars(),如果值是动态的,将不起作用,但显然,可变静态成员是 “类的默认属性”的一部分 。您可以使用以下包装器:
function get_user_prop($className, $property) { if(!class_exists($className)) return null; if(!property_exists($className, $property)) return null; $vars = get_class_vars($className); return $vars[$property]; } class Foo { static $bar = 'Fizz'; } echo get_user_prop('Foo', 'bar'); // echoes Fizz Foo::$bar = 'Buzz'; echo get_user_prop('Foo', 'bar'); // echoes Buzz
不幸的是,如果您想设置变量的值,则仍然需要使用eval(),但是在进行一些验证的情况下,它 并不是那么邪恶 。
function set_user_prop($className, $property,$value) { if(!class_exists($className)) return false; if(!property_exists($className, $property)) return false; /* Since I cannot trust the value of $value * I am putting it in single quotes (I don't * want its value to be evaled. Now it will * just be parsed as a variable reference). */ eval($className.'::$'.$property.'=$value;'); return true; } class Foo { static $bar = 'Fizz'; } echo get_user_prop('Foo', 'bar'); // echoes Fizz set_user_prop('Foo', 'bar', 'Buzz'); echo get_user_prop('Foo', 'bar'); // echoes Buzz
set_user_prop()通过此验证 应该 是安全的。如果人们开始按$className和放置随机事物$property,则它将退出该函数,因为它将不再是现有的类或属性。截至$value,它实际上从未解析为代码,因此无论它们放在那里都不会影响脚本。
set_user_prop()
$className
$property
$value