laravel 学习指南 第六章 第三节
- TOC
{:toc}
6.3 服务提交者
6.3.1 简介
服务提供者是所有laravel应用启动的中心,你自己的应用以及所有Laravel的核心服务都是通过服务提供者启动。
但是,我们所谓的启动
指的是什么?通常,这意味着注册事物,包括注册服务容器绑定,事件监听器,中间件甚至路由。服务提供者是应用配置的中心。
如果你打开Laravel自带的config/app.php
文件,将会看到一个providers
数组,这里就是应用所要加载的所有服务提供者类,当然,其中很多是延迟加载的,也就是说不是每次请求都会被加载,只有真的用到它们的时候才会加载。
本章里你将会学习如何编写自己的服务提供者并在Laravel应用中注册它们。
6.3.2 编写服务提供者
所以得服务提供者继承自Illuminate\Support\ServiceProvider
类。继承该抽象类要求至少在服务提供者中定义一个方法:register
。在register
方法内,你唯一要做的事情就是绑事物到服务容器,不要尝试在其中注册任何时间监听器,路由或者任何其它功能。
通过Artisan命令make:provider
可以简单生成一个新的提供者:
php artisan make:provider RiakServiceProvider
文件被创建到App/Providers/RiakServiceProvider.php
6.3.2.1 register方法
正如前面所提到的,在register
方法中只绑定事物到服务容器,而不要做其它事情,否则,一不小心就会用到一个尚未被加载的服务提供者提供的服务。
现在来看看一个基本的服务提供者是什么样:
1 |
|
编辑的文件为App/Providers/RiakServiceProvider.php
这个服务提供者只定义了一个register
方法,并在服务容器中使用此方法定义了一份Riak/connection
的实例。如果不清楚它是如何运作的,查看下一章节服务容器
。
6.3.2.2 boot方法
如果我们想要在服务提供者中注册视图composer该怎么做?这就要用到boot
方法,该方法在所有服务提供者被注册以后才会被调用,这就是说我们可以在其中访问框架已注册的所有其他服务:
1 |
|
- boot方法的依赖注入
我们可以在boot
方法中类型提升依赖,服务容器会自动注册你需要的依赖:
1 | use Illuminate\Contracts\Routing\ResponseFactory; |
6.3.3 注册服务提供者
所有服务提供者都是通过配置文件config/app.php
中进行注册,该文件包含了一个列出所有服务提供者名字的providers
数组,默认情况下,其中列出了所有核心服务提供者,这些服务提供者启动Laravel核心组件,比如邮件、列队、缓存等等。
要注册你自己的服务提供者,只需要将其追加到该数组中:
1 | 'providers' => [ |
6.3.4 延迟加载服务提供者
如果你的提供者仅仅只是在服务容器中注册绑定,你可以选择在延迟加载该绑,定直到注册绑定真的需要时再加载,延迟加载这样的一个提供者将会提升应用的性能,因为它不会在每次请求时都从文件系统加载。
想要延迟加载一个提供者,设置defer属性为true并定义一个provides方法,该方法返回该提供者注册的服务容器绑定:
想要延迟加载一个提供者,设置defer
属性为true
并定义一个provides
方法,该方法返回该提供者注册的服务容器绑定:
1 |
|
Laravel编译并保存所有延迟服务者提供的服务以及服务提供者的类名。
然后,只有当你尝试解析其中某个服务时Laravel才会加载其服务提交者。