guiwoda/route-binder

此包已被弃用且不再维护。作者建议使用 LaravelBA/route-binder 包。

Laravel 路由绑定,做得正确。

4.0.3 2017-06-29 17:08 UTC

This package is not auto-updated.

Last update: 2019-02-20 18:24:52 UTC


README

Laravel 路由绑定,做得正确。

Build Status

Laravel 4 或 5?

master 分支包含与 Laravel 5 兼容的代码。Laravel 5 的版本从 3.0 标签开始发布。

要获取与 Laravel 4 兼容的发布版本,请访问 laravel4 分支

问题

项目开始时很简单:一些路由、可能是一些资源控制器,以及一些参数绑定。但很快,“routes.php” 文件就开始堆积如山,有数百行,包含复杂的嵌套组和过滤器,甚至(上帝禁止)调用 App::make。更糟糕的是,必须滚动所有这些行以查找那个显然忘记的奇怪路由名,因为,谁会记得那些呢?

此包可以帮助你完成(至少)以下三件事:

  1. 通过允许你通过 IoC 容器使用 DI,将你的路由作为 应用程序 的一部分
  2. 让你将路由拆分成多个文件(类),而无需使用过时的 includesrequires
  3. 由于你将创建类,你有机会声明一些字符串常量并持有那些讨厌的路由名的引用

解决方案

此包仅包含两个契约、一个配置文件和一个 ServiceProvider

像往常一样,将 ServiceProvider 包含在你的 config/app.php 文件中,如下所示

'providers' => [
    // ...
    LaravelBA\RouteBinder\RouteBinderServiceProvider::class,
    // ...
]

然后,发布包的配置

php artisan vendor:publish --provider="LaravelBA\RouteBinder\RouteBinderServiceProvider"

之后,你需要创建一些类,这些类实现 LaravelBA\RouteBinder\Routes 接口、LaravelBA\RouteBinder\Bindings 接口或两者。别担心!你很快就会发现这是小菜一碟

namespace App\Http\Routes;

use Illuminate\Contracts\Routing\Registrar;
use Illuminate\Routing\Router;
use LaravelBA\RouteBinder\Bindings;
use LaravelBA\RouteBinder\Routes;

class FooRoutes implements Routes, Bindings
{
    /**
     * This is what I meant with #3 up there.
     * Completely optional, but highly recommended.
     */
    const INDEX = 'foo.index';

    /**
     * This one is required if you implement the Bindings interface
     */
    public function addBindings(Router $router)
    {
        $router->bind('user_id', function(){
            // Fetch your User object here!
        });
    }

    /**
     * This one is required if you implement the Routes interface
     */
    public function addRoutes(Registrar $router)
    {
        $router->get('foo', ['as' => self::INDEX, 'uses' => function(){
            return view('hello');
        }]);
    }
}

并将它们添加到已发布的配置文件中(你现在可以在 config/routes.php 中找到它)

return [
    'binders' => [
        App\Http\Routes\FooRoutes::class,
        App\Http\Routes\BarRoutes::class,
        App\Http\Routes\BazRoutes::class,
        App\Http\Routes\AwesomeRoutes::class,
    ]
];

完成了!现在,你的所有路由都组织得很好,如果事情变得不可收拾,你总是可以进一步拆分它们!

IoC 容器

我喜欢 Laravel 的路由模型绑定功能。我必须承认,我不用 Eloquent,所以我总是选择 Route::bind() 选项。

但这个功能虽然很强大,但对你架构的影响非常糟糕。在 routes.php 文件上有对数据库的调用是非常糟糕的,而且调用 App::make(SomeRepository::class) 也不见得好多少。

通过这个小小的包,你的 Bindings 对象可以依赖应用程序的任何 ServiceRepository 层。现在,你甚至可以测试这些绑定,通过模拟依赖项并期望在路由解析时调用任何 Repository::find() 方法!

这听起来可能是一个非常复杂的场景,但现在请相信我,你会喜欢的。