서비스 제공자
ㅋㅋ
- 등록 방법
- Bootstrap 방법
- Start 방법 의존성 주입
- 지연된 제공자
서비스 제공자
소개
서비스 제공업체는 모든 Laravel 애플리케이션의 부트스트래핑 센터입니다. 서버를 통해 부트스트랩된 핵심 Laravel 서비스뿐만 아니라 귀하의 애플리케이션도 서비스 제공자를 통해 부트스트랩됩니다.
그런데 '안내'가 무슨 뜻인가요? 일반적으로 서비스 컨테이너 바인딩, 이벤트 리스너, 미들웨어 및 라우팅 등록과 같은 등록으로 이해될 수 있습니다. 서비스 공급자는 애플리케이션 구성의 핵심입니다.
Laravel의
config/app.php
파일을 열면providers
배열을 볼 수 있습니다. 배열의 내용은 애플리케이션이 로드할 모든 서비스 공급자의 클래스입니다. 물론 모든 요청에 대해 로드되지 않고 해당 서비스가 실제로 필요할 때만 로드되는 "게으른" 공급자가 많이 있습니다.config/app.php
文件时,你会看到providers
数组。数组中的内容是应用程序要加载的所有服务提供者的类。当然,其中有很多 「延迟」 提供者,他们并不会在每次请求的时候都加载,只有他们的服务实际被需要时才会加载。本篇你将会学到如何编写自己的服务提供者,并将其注册到你的 Laravel 应用程序中
编写服务提供者
所有的服务提供者都会继承
IlluminateSupportServiceProvider
类。 大多服务提供者都包含一个register
和一个boot
方法。在register
方法中, 你只需要将事物绑定到服务容器。而不要尝试在register
方法中注册任何监听器,路由,或者其他任何功能使用 Artisan 命令行工具,通过
make:provider
命令可以生成一个新的提供者:php artisan make:provider RiakServiceProvider
注册方法
如上所述,在
register
方法中,你只需要将服务绑定到服务容器中。而不要尝试在register
方法中注册任何监听器,路由,或者其他任何功能。否则,你可能会意外地使用到尚未加载的服务提供者提供的服务。让我们来看一个基础的服务提供者。在任何服务提供者方法中,你总是通过
$app
属性来访问服务容器:<?php namespace App\Providers;use Riak\Connection; use Illuminate\Support\ServiceProvider; class RiakServiceProvider extends ServiceProvider{ /** * 在服务容器里注册 * * @return void */ public function register() { $this->app->singleton(Connection::class, function ($app) { return new Connection(config('riak')); }); } }
这个服务容器只是定义了一个
이 기사에서는 자신만의 서비스 공급자를 작성하고 이를 Laravel 애플리케이션에 등록하는 방법을 배웁니다.🎜🎜🎜🎜🎜Writing Service Provider🎜 🎜모든 서비스 공급자는register
方法,并且使用该这个方法在服务容器中定义了一个RiakConnection
IlluminateSupportServiceProvider
클래스. 대부분의 서비스 제공업체에는register
및boot
메서드가 포함되어 있습니다.register
메소드에서는 서비스 컨테이너에 사물을 바인딩하기만 하면 됩니다.register
메소드에서 리스너, 경로 또는 기타 기능을 등록하려고 시도하지 마세요🎜🎜Artisan 명령줄 도구를 사용하여make:provider
를 통해 새 기능을 생성하세요 명령 제공자: 🎜<?php namespace App\Providers; use App\Contracts\ServerProvider; use App\Contracts\DowntimeNotifier; use Illuminate\Support\ServiceProvider; use App\Services\PingdomDowntimeNotifier; use App\Services\DigitalOceanServerProvider; class AppServiceProvider extends ServiceProvider{ /** * 设定所有的容器绑定的对应关系 * * @var array */ public $bindings = [ ServerProvider::class => DigitalOceanServerProvider::class, ]; /** * 设定所有的单例模式容器绑定的对应关系 * * @var array */ public $singletons = [ DowntimeNotifier::class => PingdomDowntimeNotifier::class, ]; }
🎜🎜🎜등록 방법
🎜위에서 언급한 것처럼register
방법에는 다음이 필요합니다. 서비스는 서비스 컨테이너에 바인딩됩니다.register
메서드에 리스너, 경로 또는 기타 기능을 등록하려고 시도하지 마세요. 그렇지 않으면 아직 로드되지 않은 서비스 제공업체의 서비스를 실수로 사용할 수 있습니다. 🎜🎜기본 서비스 제공자를 살펴보겠습니다. 모든 서비스 제공자 방법에서는 항상$app
속성을 통해 서비스 컨테이너에 액세스합니다. 🎜<?php namespace App\Providers; use Illuminate\Support\ServiceProvider; class ComposerServiceProvider extends ServiceProvider{ /** * 启动所有的应用服务。 * * @return void */ public function boot() { view()->composer('view', function () { // }); } }
🎜이 서비스 컨테이너는 단지register
방법을 정의하고 이 방법이 정의한 것을 사용합니다. 서비스 컨테이너의RiakConnection
인터페이스. 서비스 컨테이너의 작동 방식을 이해하지 못하는 경우 해당 설명서를 확인하세요. 🎜
의 기능바인딩
및싱글턴
서비스 제공업체가 여러 단순 바인딩을 등록한 경우
바인딩
및 각 컨테이너 바인딩을 수동으로 등록하는 대신싱글톤
속성을 사용하세요. 서비스 제공자가 프레임워크에 의해 로드되면 이러한 속성이 자동으로 확인되고 해당 바인딩이 등록됩니다.bindings
和singletons
的特性如果你的服务提供器注册了许多简单的绑定,你可能想用
bindings
和singletons
属性替代手动注册每个容器绑定。当服务提供器被框架加载时,将自动检查这些属性并注册相应的绑定use Illuminate\Contracts\Routing\ResponseFactory; public function boot(ResponseFactory $response){ $response->macro('caps', function ($value) { // }); }
引导方法
如果我们要在服务提供者中注册一个 视图合成器 该怎么做? 这就需要用到
boot
方法了。 该方法在所有服务提供者被注册以后才会被调用, 这就是说我们可以在其中访问框架已注册的所有其它服务:'providers' => [ // 其他服务提供者 App\Providers\ComposerServiceProvider::class,],
启动方法的依赖注入
你可以为服务提供者的
boot
方法设置类型提示。 服务容器 会自动注入你所需要的依赖:<?php namespace App\Providers; use Riak\Connection; use Illuminate\Support\ServiceProvider; use Illuminate\Contracts\Support\DeferrableProvider; class RiakServiceProvider extends ServiceProvider implements DeferrableProvider{ /** * 注册服务提供者。 * * @return void */ public function register() { $this->app->singleton(Connection::class, function ($app) { return new Connection($app['config']['riak']); }); } /** * 获取由提供者提供的服务。 * * @return array */ public function provides() { return [Connection::class]; } }
注册服务提供者
所有服务提供者都是通过配置文件
config/app.php
进行注册。该文件包含了一个列出所有服务提供者名字的providers
数组,默认情况下,其中列出了所有核心服务提供者,这些服务提供者启动 Laravel 核心组件,比如邮件、队列、缓存等等。要注册提供器,只需要将其添加到数组:
rrreee延迟提供者
如果你的服务提供者 只 在 服务容器 中注册,可以选择延迟加载该绑定直到注册绑定的服务真的需要时再加载,延迟加载这样的一个提供者将会提升应用的性能,因为它不会在每次请求时都从文件系统加载。
Laravel 编译并保存延迟服务提供者提供的所有服务的列表,以及其服务提供者类的名称。因此,只有当你在尝试解析其中一项服务时,Laravel 才会加载服务提供者。
要延迟加载提供者,需要实现
IlluminateContractsSupportDeferrableProvider
接口并置一个provides
方法。这个provides
rrreeerrreee부팅 방법
< p >서비스 제공업체에 뷰 합성기를 등록하려면 어떻게 해야 합니까? 이를 위해서는boot
방법을 사용해야 합니다. 이 메소드는 모든 서비스 제공자가 등록될 때까지 호출되지 않습니다. 이는 프레임워크에 등록된 다른 모든 서비스에 액세스할 수 있음을 의미합니다. rrreee메소드 종속성 주입 시작다음을 수행할 수 있습니다. 서비스 제공자의
boot
메소드에 대한 유형 힌트를 설정합니다. 서비스 컨테이너는 필요한 종속성을 자동으로 주입합니다.
- 바인딩 및 싱글톤의 특징
서비스 제공자 등록
모든 서비스 제공자는 File config/app.php
를 등록합니다. 이 파일에는 모든 서비스 제공자의 이름을 나열하는 providers
배열이 포함되어 있습니다. 기본적으로 모든 핵심 서비스 제공자는 메일, 캐시 등과 같은 Laravel 핵심 구성요소를 시작합니다. . 🎜
공급자를 등록하려면 다음 배열에 추가하세요: 🎜rrreee