>백엔드 개발 >PHP 튜토리얼 >Laravel의 Facade란 무엇입니까?

Laravel의 Facade란 무엇입니까?

黄舟
黄舟원래의
2017-09-23 09:12:392500검색

Facade는 실제로 컨테이너에 있는 클래스의 정적 프록시입니다. 이를 통해 컨테이너에 저장된 모든 개체의 메서드를 정적으로 호출할 수 있습니다. 다음 글은 Laravel에서 Facade의 로딩 과정과 원리에 대한 관련 정보를 주로 소개합니다.

Laravel의 Facade란 무엇입니까?

공식 문서에 제공된 정의

"Facade는 애플리케이션의 서비스 컨테이너에 "정적" 인터페이스를 제공합니다. Laravel에는 대부분의 기능에 대한 액세스를 제공하는 많은 Facade가 포함되어 있습니다. Laravel Facades는 실제로 서비스 컨테이너의 기본 클래스에 대한 "정적 프록시"입니다. 전통적인 정적 방법과 비교하여 사용 시 더 유연하고, 테스트하기 쉽고, 더 우아한 구문을 제공할 수 있습니다. "

객체의 특정 메소드에 액세스하기 위해 긴 네임스페이스 목록을 사용하거나 객체를 인스턴스화할 필요가 없습니다.

use Config;

class Test
{
 public function index()
 {
 return Config::get('app.name');
 }
}

Facade 시작 및 등록

Facade 시작 부팅은 IlluminateFoundationBootstrapRegisterFacades에 등록됩니다.

public function bootstrap(Application $app)
{
 Facade::clearResolvedInstances();
 Facade::setFacadeApplication($app);

 AliasLoader::getInstance(array_merge(
 $app->make('config')->get('app.aliases', []),
 $app->make(PackageManifest::class)->aliases()
 ))->register();
}

The 기본 별칭 구성은 앱 구성 파일 아래의 별칭에서 읽혀집니다. PackageManifest는 laravel 5.5의 새로운 패키지 자동 검색 규칙입니다. 여기서는 당분간 PackageManifest 패키지에서 제공하는 별칭을 고려하지 않습니다. . 다음 형식의 배열:

 "App" => "Illuminate\Support\Facades\App"
 "Artisan" => "Illuminate\Support\Facades\Artisan"
 "Auth" => "Illuminate\Support\Facades\Auth"
 "Blade" => "Illuminate\Support\Facades\Blade"
 ...

위 코드는 AliasLoader를 통해 모든 Facade를 자동 로딩에 등록합니다. 핵심은 php의 spl_autoload_register입니다.

 /**
 * Prepend the load method to the auto-loader stack.
 *
 * @return void
 */
 protected function register()
 {
 if (! $this->registered) {
  spl_autoload_register([$this, 'load'], true, true);

  $this->registered = true;
 }
 }

등록이 완료된 후 모든 후속 사용 클래스는 로드 기능을 통해 완료됩니다.

참고:

spl_autoload_register를 정의할 때 이 매개변수가 true로 전달되면 spl_autoload_register()는 대기열의 끝이 아닌 대기열의 헤드에 함수를 추가합니다. . 이 기능을 통해 자동 로딩을 우선시합니다) 즉,

<?php

use Config;
use App\User;

class Test
{
 public function index()
 {
 Config::get(&#39;app.name&#39;);
 new User();
 }
}

기존의 특정 클래스(AppUser) 또는 별칭(Config)을 무엇을 사용하든 로드 기능을 통해 먼저 자동 로딩이 완료됩니다. 이 함수가 false를 반환하면 다른 자동 로딩 기능이 자동 로딩을 완료합니다(예: 작곡가 psr-4).

AliasLoader의 로드 메서드에서 class_alias 함수는 주로 별칭 자동 로딩을 구현하는 데 사용됩니다.

public function load($alias)
{
 if (isset($this->aliases[$alias])) {
 return class_alias($this->aliases[$alias], $alias);
 }
}

소개. class_alias 공식적인 예는 다음과 같습니다:

class foo { }

class_alias(&#39;foo&#39;, &#39;bar&#39;);

$a = new foo;
$b = new bar;

// the objects are the same
var_dump($a == $b, $a === $b); //true
var_dump($a instanceof $b); //false

// the classes are the same
var_dump($a instanceof foo); //true
var_dump($a instanceof bar); //true

var_dump($b instanceof foo); //true
var_dump($b instanceof bar); //true

Facade loading

Facade를 사용할 때 다음과 같습니다.

<?php

use Config;

class Test
{
 public function index()
 {
 Config::get(&#39;app.name&#39;);
 }
}

실제로 로드되는 것은 IlluminateSupportFacadesConfig 클래스입니다(class_alias를 등록했기 때문에). :

<?php

use Illuminate\Support\Facades\Config;

class Test
{
 public function index()
 {
  Config::get(&#39;app.name&#39;);
 }
}

모든 Facade는 IlluminateSupportFacadesFacade 클래스에서 상속되며, 이 기본 클래스에 __callStatic 메소드가 정의되어 있어 (인스턴스화 없이) Facade를 쉽게 사용할 수 있습니다.

<?php

public static function __callStatic($method, $args)
{
 $instance = static::getFacadeRoot();

 if (! $instance) {
  throw new RuntimeException(&#39;A facade root has not been set.&#39;);
 }

 return $instance->$method(...$args);
}

getFacadeRoot 메소드를 사용하여 별칭 클래스를 얻습니다. , 우리는 모든 Facade 클래스가 getFacadeAccessor 메소드를 정의해야 한다는 것을 알고 있습니다. 이 메서드의 가능한 반환 값은 다음과 같습니다.

문자열 유형 문자열(예: config, db)
  • 문자열 유형 문자열 유사(예: AppServiceSomeService)
  • 객체 특정 구체화된 객체
  • Closure closure
  • 예를 들어 Config Facade의 getFacadeAccessor 메소드는 다음과 같습니다:
  • protected static function getFacadeAccessor()
    {
     return &#39;config&#39;;
    }
getFacadeRoot 메소드는 getFacadeAccessor() 의 반환 값을 기반으로 컨테이너에서 해당 실제 열 개체를 검색합니다. >.

public static function getFacadeRoot()
{
 $name = static::getFacadeAccessor();
 
 if (is_object($name)) {
  return $name;
 }

 if (isset(static::$resolvedInstance[$name])) {
  return static::$resolvedInstance[$name];
 }

 return static::$resolvedInstance[$name] = static::$app[$name];
}

config 열이 APP 컨테이너

<?php
//Illuminate\Foundation\Bootstrap/LoadConfiguration

$app->instance(&#39;config&#39;, $config = new Repository($items));
getFacadeAccessor() 的返回值,从容器从取出对应的实列对象。

rrreee

由于 APP 容器中已经注册过 config 的实列

rrreee

所以 Config::get('app.name', 'dafault) 实际访问的是 Repository 实列的 get('app.name', 'default') 에 등록되었으므로 Config::get('app.name', 'dafault) 는 실제로 Repository 열 get( 'app.name', 'default') 메소드.

더 많은 관련 지식을 알고 싶으시다면 PHP 중국어 홈페이지를 방문해주세요! !

위 내용은 Laravel의 Facade란 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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