ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
ルートグループとは
Laravel の Route::group() は、複数のルートに共通する prefix / middleware / name / namespace / domain をまとめて指定できる仕組みです。共通項を一カ所で宣言できるので、コードの重複を大きく減らせます。
最もシンプルな例
use Illuminate\Support\Facades\Route;
Route::prefix('article')->group(function () {
Route::get('', [ArticleController::class, 'index']); // /article
Route::get('old', [ArticleController::class, 'getOld']); // /article/old
Route::get('diff', [ArticleController::class, 'getDiff']); // /article/diff
});
3 つのルートすべてに /article が付き、URL が共通します。
主な修飾メソッド
| メソッド | 役割 | 例 |
|---|---|---|
prefix() | URL の接頭辞 | admin → /admin/... |
middleware() | ミドルウェア | ["auth", "verified"] |
name() | ルート名の接頭辞 | admin. → admin.users.index |
controller() | 同一コントローラを束ねる | UserController::class |
domain() | サブドメイン | {tenant}.example.com |
namespace() | コントローラの名前空間 | App\Http\Controllers\Admin(L8 以降は非推奨) |
withoutMiddleware() | 個別にミドルウェア除外 | [VerifyCsrfToken::class] |
prefix(URL 接頭辞)
Route::prefix('api/v1')->group(function () {
Route::get('users', [UserController::class, 'index']); // /api/v1/users
Route::get('users/{id}', [UserController::class, 'show']); // /api/v1/users/{id}
Route::post('users', [UserController::class, 'store']); // /api/v1/users
});
middleware(共通の認証・権限)
Route::middleware(['auth', 'verified'])->group(function () {
Route::get('/dashboard', [DashboardController::class, 'index'])->name('dashboard');
Route::get('/profile', [ProfileController::class, 'edit'])->name('profile.edit');
});
// 管理者専用
Route::middleware(['auth', 'can:admin'])->prefix('admin')->name('admin.')->group(function () {
Route::get('users', [Admin\UserController::class, 'index'])->name('users.index');
Route::get('logs', [Admin\LogController::class, 'index'])->name('logs.index');
});
name(ルート名接頭辞)
name() はルート名にドット区切りで接頭辞を付けます。route(\'admin.users.index\') で参照できます。
Route::name('admin.')->prefix('admin')->group(function () {
Route::get('users', [Admin\UserController::class, 'index'])->name('users.index');
// ルート名: admin.users.index
});
controller(同じコントローラを束ねる)
Laravel 8 から、同じコントローラを使うルートを controller() でまとめられます。配列の代わりにメソッド名だけ書けるのですっきりします。
Route::controller(UserController::class)->prefix('users')->group(function () {
Route::get('', 'index')->name('users.index');
Route::get('{id}', 'show')->name('users.show');
Route::post('', 'store')->name('users.store');
Route::put('{id}', 'update')->name('users.update');
Route::delete('{id}', 'destroy')->name('users.destroy');
});
domain(サブドメイン)
マルチテナント SaaS でよく使うパターン。
Route::domain('{tenant}.example.com')->group(function () {
Route::get('/', function (string $tenant) {
return "Tenant: $tenant";
});
});
グループの入れ子
グループは入れ子にできます。外側と内側の prefix / middleware / name はすべて連結されます。
Route::middleware(['auth'])->prefix('admin')->name('admin.')->group(function () {
Route::get('dashboard', [DashboardController::class, 'index'])->name('dashboard');
// middleware: auth
// URL: /admin/dashboard
// name: admin.dashboard
Route::middleware(['can:logs'])->prefix('logs')->name('logs.')->group(function () {
Route::get('', [LogController::class, 'index'])->name('index');
// middleware: auth, can:logs
// URL: /admin/logs
// name: admin.logs.index
});
});
API バージョニングの実例
Route::prefix('api')->middleware('api')->group(function () {
Route::prefix('v1')->name('api.v1.')->group(function () {
Route::apiResource('users', Api\V1\UserController::class);
Route::apiResource('articles', Api\V1\ArticleController::class);
});
Route::prefix('v2')->name('api.v2.')->group(function () {
Route::apiResource('users', Api\V2\UserController::class);
Route::apiResource('articles', Api\V2\ArticleController::class);
});
});
認証エリアの典型構成
// ゲスト
Route::middleware('guest')->group(function () {
Route::get('login', [AuthController::class, 'showLogin'])->name('login');
Route::post('login', [AuthController::class, 'login']);
Route::get('register', [AuthController::class, 'showRegister'])->name('register');
});
// ログイン済みユーザ
Route::middleware('auth')->group(function () {
Route::post('logout', [AuthController::class, 'logout'])->name('logout');
Route::prefix('mypage')->name('mypage.')->group(function () {
Route::get('', [MypageController::class, 'index'])->name('index');
Route::get('edit', [MypageController::class, 'edit'])->name('edit');
});
});
withoutMiddleware で個別除外
大きなグループの一部だけミドルウェアを外したいときに使います。
Route::middleware('auth')->group(function () {
Route::get('/dashboard', [DashboardController::class, 'index']);
// この 1 つだけ auth を外したい(公開コールバック等)
Route::post('/webhook', [WebhookController::class, 'handle'])
->withoutMiddleware('auth');
});
route:list で確認
定義したグループが意図通りに展開されているかは、Artisan コマンドで確認します。
php artisan route:list
php artisan route:list --name=admin # 名前フィルタ
php artisan route:list --path=admin # パスフィルタ
よくあるトラブル
| 症状 | 原因と対処 |
|---|---|
| 名前付きルートが見つからない | 外側で name() を付けるのを忘れている。php artisan route:list --name=... で確認 |
| middleware が効かない | app/Http/Kernel.php に登録漏れ / グループ外で個別 middleware が上書きしている |
| prefix が二重に付く | 外側 + 内側で同じ prefix を指定している。入れ子の重複に注意 |
| controller() を使ってもメソッドが見つからない | 古い Laravel(< 8)。配列形式 [Class::class, "method"] を使う |
| サブドメインルートが効かない | キャッシュ削除(route:clear)/ Web サーバのワイルドカード DNS / 仮想ホスト設定を確認 |
関連
- ルーティング — 親カテゴリ
- Route::resource — リソースコントローラ
- middleware — ミドルウェア
- route() ヘルパ — ルート名から URL 生成
- route:cache / route:list — キャッシュ・一覧
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページ
子ページはありません
同階層のページ
- ルーティング一覧の確認方法
- ルーティングのグループ化
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- IPv6とは|128bitアドレス・コロン16進表記/::省略・リンクローカル・SLAAC・デュアルスタック NEW 2026-06-22 12:34:44
- MAC アドレスフィルタリングの仕組みと限界 | ネットワーク入門 NEW 2026-06-22 12:19:10
- VPNとは|暗号トンネル・サイト間/リモートアクセス・IPsec/SSL-VPN/WireGuardを解説 NEW 2026-06-22 12:19:10
- WebSocket とは 全二重リアルタイム通信 ws/wss | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/2 とは 多重化・HPACK・バイナリフレーム | ネットワーク入門 NEW 2026-06-22 12:17:25
- Web通信プロトコル入門 HTTP/2・HTTP/3・WebSocket・gRPC・WebRTC | ネットワーク入門 NEW 2026-06-22 12:17:25
- gRPC とは HTTP/2 + Protocol Buffers の高速 RPC | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/3 (QUIC) とは UDP ベースの低遅延 Web 通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- WebRTC とは ブラウザ間 P2P の音声・映像・データ通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- TLS/SSLの仕組み|ハンドシェイク・暗号スイート・前方秘匿性・証明書検証をわかりやすく解説 NEW 2026-06-22 12:17:24
- ファイアウォールとは|パケットフィルタ・ステートフル・DMZ・次世代FW(L4/L7)を解説 NEW 2026-06-22 12:17:24
- iptables/nftablesとは|テーブル・チェーン・ルール例・永続化をLinux視点で解説 NEW 2026-06-22 12:17:24
- HAProxy とは frontend/backend と設定例 | ネットワーク入門 NEW 2026-06-22 12:17:24
- CDN とは エッジキャッシュ・TTL・Cloudflare/CloudFront | ネットワーク入門 NEW 2026-06-22 12:17:24
- 証明書と認証局(CA)とは|X.509・信頼チェーン・DV/OV/EV・失効(CRL/OCSP)を解説 NEW 2026-06-22 12:17:24
コメントを削除してもよろしいでしょうか?