如果您使用的是 PHP 5.3.0 或更高版本,则可以使用以下方法:
$classname::$$propertyname;
不幸的是,如果您使用的是低于5.3.0的版本,则使用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