如何在 Laravel 5.1 中创建服务 Service Provider

澳门新葡亰赌995577 1

本文由码农网 –
任琦磊原创翻译,转载请看清文末的转载要求,欢迎参与我们的付费投稿计划!

本文实例讲述了Laravel框架路由和控制器的绑定操作方法。分享给大家供大家参考,具体如下:

这是一份面向初学者的 Laravel 5.1 中构建 Service Provider 的教程。

路由和控制器的关系

我在自己过去的博客中提到了我喜欢 Laravel
5.1 的架构,尤其是它引入了Service
Provider,从而使你模块化的构建应用成为了可能。应用的配置常常可能成为棘手的任务,完全取决于你正在使用的框架,但幸运的是,我们正在使用的 Laravel 让这件事变得相当简单。

路由文件地址在appHttproutes.php,我们来看两种不同的路由。

澳门新葡亰赌995577 1

Route::get { return view;Route::get { return 'hello world';});

所以让我们开始创建一个用于演示的路由(route)。到 app/Http/routes.php中添加下面这条路由:

以上均为绑定匿名函数的路由,虽然可以返回视图,也可以返回字符串,但本质都是一样的。

Route::resource('demo', 'DemoController');
Route::get('/blog','BlogController@index');Route::get('/post/{slug}','BlogController@showPost');

通过使用 Route::resource,我们就获得了预定义好的 index,show,create,edit,update,store 和 destroy 路由。

这两种是绑定控制器的路由,控制器类BlogController下有两个函数,index和showPost,可以调用。

为了实现良好的对称性,现在我们可以使用 artisan 命令行工具来为我们创建对应的控制器(controller)。键入如下指令:

那么问题来了,究竟应该选用哪种?

php artisan make:controller DemoController

你不可能把复杂的业务逻辑都写在一个匿名函数里,所以你要学会新建控制器。

让我们打开创建好的文件,将 index 方法修改为如下内容:

Route::get('/mvc', 'MyController@hello');
public function index()
{
    return view('demo.index');
}

澳门新葡亰赌995577,添加新控制器

现在让我们继续在 app/Resources/views 目录下创建一个名为 Demo 的文件夹,并在文件夹中创建一个名为 index.blade.php 的视图(view)文件,内容如下:

控制器文件夹地址在Laravel文件夹下appHttpControllers,我们继续使用artisan控制台创建一个新控制器

@extends('layouts.master')

@section('content')
<h1>Demo Page</h1>
@endsection
php artisan make:controller MyController

这个例子中我们正在调用一个我已经在 layouts 文件夹中创建了的 master 页面master.blade.php。如果你的 master 用了另一个名字,那么这里你得替换掉。如果你没有 master 页面,那么就删掉第一行 extends 的全部内容,包括 @sectioin 申明。

然后,回到控制器目录,一份新的MyController.php文件被创建了,代码如下:

假设你已经配置好了你的开发环境并解析了你的域名,那么当你访问路由yourapplication.com/demo,你应该可以看到内容 Demo
Page 了。

我们修改MyController类,同时再创建一个视图。如果这么写,就意味着一旦用户访问URL:laravel/public/mvc,路由就会交给MyController控制器的hello函数,hello函数返回myview视图,即返回myview.blade.php我们看看myview.blade.php的代码@extends@section    {{ $d1 }}  this is my view!    @endsection

好的,那么现在就让我们来创建一个Service Provider。这个Service
Provider不会做太多特别有用的事情。它只是用来向你展示如何搭建它。

这里的{{ $d1 }}希望用一个变量的值来代替,所以,我们把MyController控制器修改为

让我们在 app 目录下创建一个 Helpers 文件夹。然后在 Helpers 文件夹里,创建一个 Contracts 文件夹。在 Contracts 文件夹里,创建文件RocketShipContract.php 并写入下面的内容:

class MyController extends Controller{ public function hello() { return View('myview',['d1'=>'a1']); }}
<?php

namespace AppHelpersContracts;

Interface RocketShipContract
{

    public function blastOff();

}

更多关于Laravel相关内容感兴趣的读者可查看本站专题:《Laravel框架入门与进阶教程》、《php优秀开发框架总结》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》

正如你所知,接口(interface)是一种用来强化架构的契约(contract)。为了定义类的接口,它必须包含名为 blastOff 的公共函数(public
function)。

希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。

所以为什么要费力地创建一个契约呢?其实,Laravel 有一个神奇的功能是你可以类型提示契约,Service
Provider会返回一个受它约束的具体类的实例。这实现了无与伦比的灵活性和松耦合的结构,因为你的工作将可以轻松地通过一行代码来完成。我们即将看到这是如何工作的。

首先,让我们创建一个具体类。在 app/Helpers 文件夹中,创建RocketShip.php,代码如下:

<?php

namespace appHelpers;

use AppHelpersContractsRocketShipContract;

class RocketShip implements RocketShipContract
{

    public function blastOff()
    {

        return 'Houston, we have ignition';

    }

}

你可以看到我们的具体类没有做很多事,但我们则对如何配合在一起更感兴趣。你可以自己决定你想给你的应用提供什么服务。

好的,现在我们要来创建一个符合契约和具体类的Service
Provider了。在命令行中键入下面的指令:

php artisan make:provider RocketShipServiceProvider

回车确认,它就会为你创建好一个类。

新文件位于 app/Providers。前往这个文件,修改为如下内容:

<?php

namespace AppProviders;

use IlluminateSupportServiceProvider;
use AppHelpersRocketLauncher;

class RocketShipServiceProvider extends ServiceProvider
{
    protected $defer = true;

    /**
     * Bootstrap the application services.
     *
     * @return void
     */
    public function boot()
    {
        //
    }
    /**
     * Register the application services.
     *
     * @return void
     */
    public function register()
    {
        $this->app->bind('AppHelpersContractsRocketShipContract', function(){

            return new RocketShip();

        });
    }

    /**
     * Get the services provided by the provider.
     *
     * @return array
     */
    public function provides()
    {
        return ['AppHelpersContractsRocketShipContract'];
    }

}

让我们看一下这一段:

<?php

namespace AppProviders;

use IlluminateSupportServiceProvider;
use AppHelpersRocketShip;

class RocketShipServiceProvider extends ServiceProvider
{

简单粗暴。我们有了命名空间,use 申明和 class 申明。当你创建Service
Provider时,你要导入(import)具体类,像这里我在 use 申明中导入了 RocketShip。

接下来是:

protected $defer = true;

发表评论

电子邮件地址不会被公开。 必填项已用*标注

相关文章

网站地图xml地图