Я расскажу вам об основных рекомендациях по организации файлов маршрутов, что бы вы не забывали что и где находится.
Простые приложения могут использовать файлы routes/web.php
или routes/api.php
для описания своих маршрутов. Поскольку они небольшие, то писать-то им особо и нечего.
В других приложениях может быть и полсотни и больше сотни маршрутов. Вместо того, чтобы продолжать набивать их в один файл, можно организовать свои маршруты в отдельные файлы.
Просто добавьте еще один файл
Перейдите в App/Providers/RouteServiceProvider
и найдите метод map()
. Здесь сервис-провайдер составляет карту ваших маршрутов. Смотрите — API и Web маршруты обрабатываются другими методами.
Вы можете просто скопипастить код в mapWebRoutes() и изменить файл группы на тот, который вам нужен:
/** * Определение маршрутов для приложения. * * @return void */ public function map() { $this->mapApiRoutes(); $this->mapWebRoutes(); Route::middleware('web') ->namespace($this->namespace) ->group(base_path('routes/my-custom-routes.php')); }
Приложение обработает маршруты API, веб-маршруты и, наконец, ваши кастомные маршруты.
Группы и файлы
Фасад маршрутов позволяет создать группу маршрутов через замыкание, возвращающее больше маршрутов, но, как вы видели ранее, фреймворк начинает с вызова файла.
В ваших маршрутных файлах вы можете использовать такую же технику. Вместо использования замыкания, вы можете просто указать на другой файл, что эффективно уменьшит размер файл маршрута.
Route::name('dashboard') ->prefix('dashboard') ->namespace('Dashboard') ->middleware(['auth','verified']) ->group(__DIR__ . '/web/dashboard.php');
Затем мы можем создать файл routes/web/dashboard.php
, содержащий маршруты для нашей панели инструментов. Мы также применяем кастомное пространство имен, префикс и мидлвар для всех маршрутов и добавляем имя.
Мы можем вложить группы в группу, чтобы держать их в одном файле. Без проблем:
// routes/web/dashboard.php Route::get('/', 'HomeController'); Route::get('/account', 'AccountController@show'); Route::post('/account', 'AccountController@update'); Route::name('users') ->prefix('users') ->namespace('Users') ->middleware('can:manage-users') ->group(__DIR__ . '/dashboard/users.php'); Route::name('delivery') ->prefix('delivery') ->namespace('Delivery') ->middleware('can:manage-delivery') ->group(__DIR__ . 'dashboard/delivery.php');
Простая группа
Иногда нет необходимости помещать имена, префиксы, пространства имен и мидлвары в группу. Вы можете просто создать группу, поместить внутрь все маршруты и управлять нужными параметрами для каждого конкретного случая. Случайный пример:
// routes/web.php Route::group(__DIR__ . '/web/message.php'); // routes/web/message.php Route::get('client/send', 'MessageController@clientShow'); Route::post('client/send', 'MessageController@clientSend'); Route::get('courier/send', 'MessageController@courierShow') ->middleware('can:send-message-to-courier'); Route::get('courier/send', 'MessageController@courierShow') ->middleware('can:send-message-to-courier');
Привязываем Модель к Маршруту как префикс
Еще одна вещь, которую вы можете сделать — привязать модель к маршруту как префикс , чтобы все дочерние маршруты имели одинаковую привязку.
// routes/web.php Route::prefix('{delivery}')->group(__DIR__ . '/web/delivery.php'); // routes/web/delivery.php Route::get('/', 'DeliveryController@show'); Route::get('/routes', 'DeliveryController@routes'); Route::get('/products', 'DeliveryController@products'); Route::get('/drivers', 'DriverController@deliveryDriver');
Так что нет необходимости возводить стены маршрутов в одном файл и надеяться, что вам не понадобится карта для поиска того самого именного маршрута, который мешает другому.
Автор: Italo Baeza
Перевод: Алексей Широков
Наш Телеграм-канал — следите за новостями о Laravel.