Reflection은 PHP 실행 상태에서 PHP 프로그램 분석을 확장하고 주석을 포함하여 클래스, 메서드, 속성, 매개 변수 등에 대한 자세한 정보를 내보내거나 추출하는 것입니다. 이렇게 동적으로 정보를 얻고 객체의 메소드를 동적으로 호출하는 기능을 리플렉션 API라고 합니다. Reflection은 객체 지향 패러다임에서 메타 모델을 조작하기 위한 API로, 매우 강력하며 복잡하고 확장 가능한 애플리케이션을 구축하는 데 도움이 될 수 있습니다. 사용법은 다음과 같습니다:
자동 로딩플러그인, 자동 문서 생성, PHP 언어 확장에도 사용할 수 있습니다. PHP Reflection API는 프로그램의 메타데이터에 액세스하거나 관련 주석과 상호 작용하는 데 도움이 되는 여러 클래스로 구성됩니다. 리플렉션의 도움으로 클래스에 의해 구현된 메서드를 얻고, 클래스의 인스턴스를 생성하고(새로 생성하는 것과는 다름), 메서드를 호출하고(일반 호출과도 다름), 매개변수를 전달하고, 정적 메서드를 동적으로 호출할 수 있습니다. 클래스의 메소드. Reflection API는 일부 클래스, 예외 및 인터페이스를 포함하는 PHP의 내장형 oop 기술 확장입니다. 함께 사용하면 다른 클래스, 인터페이스, 메서드, 속성, 메서드 및 확장을 분석하는 데 도움이 될 수 있습니다. 이러한 oop 확장을 리플렉션이라고 합니다. + 다음 정보를 얻으세요--
”
Namespace
그런 다음 소스 코드를 살펴보러 갔습니다. 나는 ThinkPHPLibCoreApp.class.phpif(!preg_match('/^[A-Za-z](\w)*$/',$action)){
// 非法操作
throw new ReflectionException();
}
//执行当前操作
$method = new ReflectionMethod($module, $action); #查看方法
if($method->isPublic()) {
$class = new ReflectionClass($module); #反射控制器
// 前置操作
if($class->hasMethod('_before_'.$action)) {
$before = $class->getMethod('_before_'.$action);
if($before->isPublic()) {
$before->invoke($module);
}
}
// URL参数绑定检测
if(C('URL_PARAMS_BIND') && $method->getNumberOfParameters()>0){
switch($_SERVER['REQUEST_METHOD']) {
case 'POST':
$vars = $_POST;
break;
case 'PUT':
parse_str(file_get_contents('php://input'), $vars);
break;
default:
$vars = $_GET;
}
$params = $method->getParameters();
foreach ($params as $param){
$name = $param->getName();
if(isset($vars[$name])) {
$args[] = $vars[$name];
}elseif($param->isDefaultValueAvailable()){
$args[] = $param->getDefaultValue();
}else{
throw_exception(L('_PARAM_ERROR_').':'.$name);
}
}
$method->invokeArgs($module,$args);
}else{
$method->invoke($module); #执行我们需要调用函数
}
// 后置操作
if($class->hasMethod('_after_'.$action)) {
$after = $class->getMethod('_after_'.$action);
if($after->isPublic()) {
$after->invoke($module);
}
}
위 내용은 PHP에서 리플렉션의 정의와 사용법에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!