淺談一種Laravel路由文件劃分方式
最初,我想到了利用路由組方法可以接收文件,這就是 laravel 在 RouteServiceProvider 處拆分路由的方式。
<?php
namespace App\Providers;
use Illuminate\Foundation\Support\Providers\RouteServiceProvider as ServiceProvider;
use Illuminate\Support\Facades\Route;
class RouteServiceProvider extends ServiceProvider{
protected $namespace = 'App\Http\Controllers';
public function boot(){
parent::boot();
}
public function map(){
$this->mapApiRoutes();
$this->mapWebRoutes();
}
protected function mapWebRoutes(){
Route::middleware('web')
->namespace($this->namespace)
->group(base_path('routes/web.php'));
}
protected function mapApiRoutes(){
Route::prefix('api')
->middleware('api')
->namespace($this->namespace)
->group(base_path('routes/api.php'));
}
}
我將與用戶有關的路由抽象到了一個名為 users.php 的文件中,并將 mapApiRoutes 復制為 mapUsersRoutes 并指向到我的 users.php 文件。
public function map(){
$this->mapApiRoutes();
$this->mapWebRoutes();
$this->mapUsersRoutes();
}
protected function mapUsersRoutes(){
Route::prefix('api')
->middleware('api')
->namespace($this->namespace)
->group(base_path('routes/users.php'));
}
我知道您在想什么,顯然,這并不是最好的解決方案,因為每當我們需要創(chuàng)建新文件時,都必須像之前一樣注冊它。 因此,我不得不改進這個最初的想法。
我想到了將整個應用程序中的公共部分拆分成單獨的路由文件,并且我想到我們的所有路由都不能超出已認證、訪客和公共路由的范圍。
我將路由文件夾的結構優(yōu)化成下面這樣:
├── routes
│ ├── api
│ │ ├── public
│ | │ ├── users.php
│ │ ├── auth
│ | │ ├── users.php
│ │ ├── guest
│ | │ ├── users.php
乍一看,您可能會認為 “嗯,它并沒有太大變化,我們還是需要去映射這些文件”。 但是,實際上我們可以利用 php 原生提供的名為 glob 的函數(shù),這是一種開箱即用的解決方案,因為我們沒有與 laravel 的解決方案耦合。
glob 接收一個正則,并且可以在與我們的正則匹配的路徑下找到文件名。 因此,我們的路由是在特定文件夾下組織的,我們現(xiàn)在可以在這些文件夾下找到所有文件,并將它們注冊到其中間件。
<?php
namespace App\Providers;
use Illuminate\Foundation\Support\Providers\RouteServiceProvider as ServiceProvider;
use Illuminate\Support\Facades\Route;
class RouteServiceProvider extends ServiceProvider{
protected $namespace = 'App\Http\Controllers';
public function map(){
$this->mapAuthRoutes();
$this->mapGuestRoutes();
$this->mapPublicRoutes();
}
protected function mapWebRoutes(){
Route::middleware('web')
->namespace($this->namespace)
->group(base_path('routes/web.php'));
}
protected function mapAuthRoutes(){
foreach (glob(base_path('routes/api/auth/*.php')) as $file) {
Route::prefix('api')
->middleware(['api', 'auth:api'])
->group($file);
}
}
protected function mapGuestRoutes(){
foreach (glob(base_path('routes/api/guest/*.php')) as $file) {
Route::prefix('api')
->middleware(['api', 'guest:api'])
->group($file);
}
}
protected function mapPublicRoutes(){
foreach (glob(base_path('routes/api/public/*.php')) as $file) {
Route::prefix('api')
->middleware('api')
->group($file);
}
}
}
現(xiàn)在,無論何時我們創(chuàng)建一個新文件,foreach 都將找到它,因為它是使用正則匹配(該文件位于對應的路徑下,并且具有 PHP 擴展名,因此它與我們的正則匹配)。簡直太騷了!但是請稍等片刻。
這些文件將如何注冊?
如果您研究過 laravel 的生命周期,您就知道服務提供者是 laravel 請求的生命周期的一部分,我們可以利用此功能動態(tài)注冊我們的路線。
以上就是淺談一種Laravel路由文件劃分方式的詳細內(nèi)容,更多關于一種Laravel路由文件劃分方式的資料請關注腳本之家其它相關文章!
相關文章
php檢測apache mod_rewrite模塊是否安裝的方法
這篇文章主要介紹了php檢測apache mod_rewrite模塊是否安裝的方法,通過對apache mod_rewrite模塊相關函數(shù)的檢測實現(xiàn)該檢測功能,需要的朋友可以參考下2015-03-03
PHP+FLASH實現(xiàn)上傳文件進度條相關文件 下載
PHP+FLASH實現(xiàn)上傳文件進度條相關文件 下載...2007-07-07
PHP簡單實現(xiàn)二維數(shù)組賦值與遍歷功能示例
這篇文章主要介紹了PHP簡單實現(xiàn)二維數(shù)組賦值與遍歷功能,涉及php數(shù)組的簡單賦值、遍歷、運算、讀取等操作使用技巧,需要的朋友可以參考下2017-10-10
如何在symfony中導出為CSV文件中的數(shù)據(jù)
如果您需要在symfony中將數(shù)據(jù)庫中的數(shù)據(jù)導出為CSV文件,試試這個2011-10-10

