反射 API 提供了 getAttributes() 方法, 類、方法、函數、參數、屬性、類常量的反射對象可通過它獲取相應的注解。 該方法返回了 ReflectionAttribute 實例的數組, 可用于查詢注解名稱、參數、也可以實例化一個注解。
實例和反射注解的分離使得程序員增加了在丟失反射類、類型錯誤、丟失參數等情況下的處理能力,也能處理錯誤。 只有調用 ReflectionAttribute::newInstance() 后,注解類的對象才會以驗證過匹配的參數來實例化。
示例 #1 通過反射 API 讀取注解
<?php
#[Attribute]
class MyAttribute
{
public $value;
public function __construct($value)
{
$this->value = $value;
}
}
#[MyAttribute(value: 1234)]
class Thing
{
}
function dumpAttributeData($reflection) {
$attributes = $reflection->getAttributes();
foreach ($attributes as $attribute) {
var_dump($attribute->getName());
var_dump($attribute->getArguments());
var_dump($attribute->newInstance());
}
}
dumpAttributeData(new ReflectionClass(Thing::class));
/*
string(11) "MyAttribute"
array(1) {
["value"]=>
int(1234)
}
object(MyAttribute)#3 (1) {
["value"]=>
int(1234)
}
*/
通過傳入參數:待搜索的注解類名,可返回指定的注解類, 而不需要再到反射類中迭代循環(huán)獲取所有注解。
示例 #2 使用反射 API 讀取指定的注解
<?php
function dumpMyAttributeData($reflection) {
$attributes = $reflection->getAttributes(MyAttribute::class);
foreach ($attributes as $attribute) {
var_dump($attribute->getName());
var_dump($attribute->getArguments());
var_dump($attribute->newInstance());
}
}
dumpMyAttributeData(new ReflectionClass(Thing::class));