PHP5 has a complete reflection API, adding the ability to reverse engineer classes, interfaces, functions, methods and extensions.
What is reflection?
It refers to extending the analysis of PHP programs in the running state of PHP and exporting or extracting detailed information about classes, methods, properties, parameters, etc., including comments. This function of dynamically obtaining information and dynamically calling methods of objects is called reflection API. Reflection is an API for manipulating meta-models in the object-oriented paradigm. It is very powerful and can help us build complex and scalable applications.
Its uses include: automatically loading plug-ins, automatically generating documents, and can even be used to expand the PHP language.
The PHP reflection api consists of several classes that help us access the metadata of the program or interact with related annotations. With the help of reflection, we can obtain the methods implemented by the class, create an instance of the class (different from creating with new), call a method (also different from the regular call), pass parameters, and dynamically call the static methods of the class.
Reflection API is PHP's built-in OOP technology extension, including some classes, exceptions and interfaces. Used together, they can be used to help us analyze other classes, interfaces, methods, properties, methods and extensions. These OOP extensions are called reflection.
Usually we use the ReflectionClass class and ReflectionMethod class more often, for example:
/**
* For the sake of demonstration, we"re setting this private
*/
private $_allowDynamicAttributes = false;
/**
* type=primary_autoincrement
*/
protected $id = 0;
/**
* type=varchar length=255 null
*/
protected $name;
/**
* type=text null
*/
protected $biography;
public function getId() {
Return $this->id;
}
public function setId($v) {
$this->id = $v;
}
public function getName() {
Return $this->name;
}
public function setName($v) {
$this->name = $v;
}
public function getBiography() {
return $this->biography;
}
public function setBiography($v) {
$this->biography = $v;
}
}
1. Through ReflectionClass, we can get the following information of the Person class:
1.Constants
2. Property Property Names
3. Method Method Names static
4. Properties Static Properties
5. Namespace Namespace
6.Whether the Person class is final or abstract
7. Does the Person class have a certain method
Next to reflect it, just pass the class name "Person" to ReflectionClass:
1) Get properties:
By default, ReflectionClass will obtain all properties, including private and protected ones. If you only want to get the private attribute, you need to pass an additional parameter:
Available parameter list:
2) Get comments:
You can get the comments written to the property through getDocComment.
3) Get the method of the class
4) Execution class method:
2. Through ReflectionMethod, we can get information about a method of the Person class:
1. Whether it is of “public”, “protected”, “private” or “static” type
2. Parameter list of method
3. Number of parameters of the method
4. Uncall the method of the class
if ($method->isPublic() && !$method->isStatic()) {
echo 'Action is right';
}
echo $method->getNumberOfParameters(); //Number of parameters
echo $method->getParameters(); // Parameter object array
array_push($_FILES[
It’s just a parameter passing, and the parameter is a class. This class conforms to the ReflectionMethod class definition.