>백엔드 개발 >PHP 튜토리얼 >PHP에서 반사 적용

PHP에서 반사 적용

不言
不言원래의
2018-06-08 15:23:051527검색

이 글은 주로 PHP에서 리플렉션을 적용하는 방법과 리플렉션이 무엇인지, 리플렉션의 역할이 무엇인지 소개합니다. 관심 있는 친구들은 참고하시면 됩니다.

리플렉션은 PHP 내보내기 실행 상태에서 PHP 프로그램을 확장 분석한 것입니다. 또는 주석을 포함하여 클래스, 메소드, 속성, 매개변수 등에 대한 자세한 정보를 추출합니다. 이렇게 동적으로 정보를 얻고 객체의 메소드를 동적으로 호출하는 기능을 리플렉션 API라고 합니다. Reflection은 객체 지향 패러다임에서 메타 모델을 조작하기 위한 API이며 매우 강력하며 복잡하고 확장 가능한 애플리케이션을 구축하는 데 도움이 될 수 있습니다.
플러그인 자동 로드, 문서 자동 생성 등의 용도가 있으며 PHP 언어 확장에도 사용할 수 있습니다.
PHP Reflection API는 프로그램의 메타데이터에 액세스하거나 관련 주석과 상호 작용하는 데 도움이 되는 여러 클래스로 구성됩니다. 리플렉션의 도움으로 클래스에 의해 구현된 메서드를 얻고, 클래스의 인스턴스를 생성하고(새로 생성하는 것과는 다름), 메서드를 호출하고(일반 호출과도 다름), 매개변수를 전달하고, 정적 메서드를 동적으로 호출할 수 있습니다. 클래스의 메소드.
            Reflection API는 일부 클래스, 예외 및 인터페이스를 포함하는 PHP의 내장형 oop 기술 확장입니다. 함께 사용하면 다른 클래스, 인터페이스, 메서드, 속성, 메서드 및 확장을 분석하는 데 도움이 될 수 있습니다. 이러한 oop 확장을 리플렉션이라고 합니다. ㅋㅋㅋ静态
     4) 属性정적 속성
     5) 命name 空间Namespace

     6) 사람 클래스가 최종인지 추상인지


그런 다음 thinkphp의 소스 코드를 살펴보고 MVC 구현에 대한 다양한 경험을 했습니다. ThinkPHPLibCoreApp.class.php



if(!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 트리를 구현하는 비재귀적 방법

PHP 캡슐화된 데이터베이스 기능 및 사용법



위 내용은 PHP에서 반사 적용의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.