ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
変更すべき箇所はバージョンと足回りで異なる
| 環境 | 変更箇所 |
|---|---|
| Laravel 6 / 7(laravel/ui 同梱の旧 UI) | App\Http\Controllers\Auth\LoginController::$redirectTo 等 |
| Laravel 8+ Breeze | app/Providers/RouteServiceProvider.php の HOME 定数 |
| Laravel 8+ Fortify / Jetstream | config/fortify.php の home または RouteServiceProvider::HOME |
| 動的振り分け(権限別) | authenticated() をオーバーライド、または LoginResponse をバインド |
① 旧 UI(Laravel 6 / 7)の場合
// app/Http/Controllers/Auth/LoginController.php
class LoginController extends Controller
{
use AuthenticatesUsers;
// ログイン成功後のリダイレクト先
protected $redirectTo = '/dashboard';
}
// app/Http/Controllers/Auth/RegisterController.php
class RegisterController extends Controller
{
use RegistersUsers;
protected $redirectTo = '/welcome';
}
// app/Http/Controllers/Auth/ResetPasswordController.php
class ResetPasswordController extends Controller
{
use ResetsPasswords;
protected $redirectTo = '/dashboard';
}
② Laravel 8+ Breeze の場合
// app/Providers/RouteServiceProvider.php
class RouteServiceProvider extends ServiceProvider
{
/**
* ログイン・登録・パスワードリセット後の共通遷移先
*/
public const HOME = '/dashboard';
}
Breeze は app/Http/Controllers/Auth/AuthenticatedSessionController.php 内部で redirect()->intended(RouteServiceProvider::HOME) を呼んでいるため、HOME 定数を変えるだけで全てのフローの遷移先が変わります。
③ Fortify / Jetstream の場合
// config/fortify.php
return [
// ...
'home' => '/dashboard', // ← ここ
// ...
];
// または RouteServiceProvider::HOME を変えても同じ
④ 動的にリダイレクト先を変える(権限別など)
「管理者なら /admin、一般ユーザーなら /dashboard」のように振り分けたい場合は、authenticated() メソッドをオーバーライドします:
// app/Http/Controllers/Auth/LoginController.php (旧 UI / 自作 Login の場合)
class LoginController extends Controller
{
use AuthenticatesUsers;
protected function authenticated($request, $user)
{
if ($user->is_admin) {
return redirect('/admin');
}
if ($user->role === 'editor') {
return redirect('/editor');
}
return redirect('/dashboard');
}
}
⑤ Fortify でレスポンサを差し替える(推奨パターン)
Fortify は 「レスポンスクラス」で挙動を変えるアーキテクチャです。コンテナにバインドし直すことでログイン・登録・PW リセット後のレスポンスを自由に変えられます。
// app/Http/Responses/LoginResponse.php
namespace App\Http\Responses;
use Illuminate\Http\Request;
use Laravel\Fortify\Contracts\LoginResponse as LoginResponseContract;
class LoginResponse implements LoginResponseContract
{
public function toResponse($request)
{
$user = $request->user();
if ($user->is_admin) {
return redirect()->intended('/admin');
}
return redirect()->intended('/dashboard');
}
}
// app/Providers/FortifyServiceProvider.php
use Laravel\Fortify\Contracts\LoginResponse as LoginResponseContract;
use App\Http\Responses\LoginResponse;
public function register()
{
$this->app->singleton(LoginResponseContract::class, LoginResponse::class);
}
同様に RegisterResponse / PasswordResetResponse / LogoutResponse もバインドできます。
⑥ intended() による「元の URL に戻す」
未ログイン状態で保護ページにアクセスし、ログインさせた後で元の URL に戻したい場合は intended() を使います:
// 未ログイン時のアクセス先を覚えている
return redirect()->intended('/dashboard');
// → 元の URL があればそこへ、無ければ /dashboard へ
// 元の URL を明示的に取得
$url = session()->pull('url.intended', '/default');
変更後の確認
# 設定キャッシュをクリア
php artisan config:clear
php artisan cache:clear
php artisan route:clear
# 実際にログインして遷移先を確認
# 404 になる場合はルート未定義
php artisan route:list | grep dashboard
FAQ
Q: ログアウト後の遷移先を変えたい
A: Breeze なら AuthenticatedSessionController::destroy() 内の redirect('/') を編集。Fortify なら LogoutResponse をバインド。
Q: SPA で API 認証している
A: API には「リダイレクト」概念は無いので、ログイン成功 JSON を返すだけ。フロント側で URL 遷移を制御します。
Q: ユーザーごとに異なる「初回ログイン処理」を入れたい
A: authenticated() 内で $user->first_login_at をチェックして、初回なら /welcome-tour へ。
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページはありません
- インストールと設定
- クイックスタート & チュートリアル(初心者向け)
- クイックスタート & チュートリアル(中級者向け)
- ルーティング
- Bladeテンプレート(ビュー/レイアウト)
- コントローラー
- マイグレーションとテーブル定義
- データベースの設定
- Eloquentモデル (ORM)
- SQLとクエリビルダー
- バリデーション
- .envファイルの設定値へのアクセス
- 動作環境による分岐処理
- configフォルダ配下の設定値へのアクセス
- assetヘルパーを利用したpublicフォルダへのアクセス
- storageフォルダへのアクセス
- アプリケーション名の変更
- メンテナンス
- ログイン画面(認証システム)の作成
- ログインの必須化
- ログインユーザー情報の取得
- ルートの認証化
- 本番サーバーへのデプロイ方法
- 多言語化
- csrf_field
- ファイルのダウンロード
- CSVのアップロードおよび読み込み(maatwebsite/excel)
- ページタイトルの設定
- コマンド一覧
- エラー一覧
- SQLの実行ログ出力方法
- キャッシュのクリア
- Selectの結果の最初もしくは最後に任意の値を追加する方法
- ajaxでPOST通信する際の注意点
- ソーシャルログインの実装
- セッション情報の確認
- ログイン、ユーザー登録、パスワードリセット後のリダイレクト先の変更方法
- redirectやreturn viewにメッセージを付与する方法
- クッキー(cookie)の設定と取得
- クラスの再読み込み
- csrfの有効時間を変更する方法
- ViewComposerを用いてviewに共通の値を付与する方法
- View::shareを用いて共通の値を各ビューに渡す方法
- ミドルウェアを用いた処理の共通化
- Middleware内でAuth::check()などを使用する方法
- Controller以外でリダイレクトする方法
- セッションの値の取得/保存/更新/削除
- $requestの値を変更する方法
- 常時SSL化
- ページング(ページネーション)をする方法
- vue.jsとの連携
- Vue.jsと連携するSPA実行環境構築
- .envの値をvue.jsで参照する方法
- vue.jsを本番環境にリリースする方法
- could not find driver(Windows, MySQL編)
人気ページ
- 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アノテーションとは
最近更新/作成されたページ
- Laravel キャッシュクリア完全ガイド(cache:clear / config:clear / 2026-05-18 07:42:07
- プロジェクトの作成と削除 2026-05-18 07:42:07
- インストール直後にNetbeansが反応しない 2026-05-18 07:42:07
- 動画やチャンネルの検索 2026-05-18 07:42:07
- APIキー取得方法 2026-05-18 07:42:07
- チャンネル情報の取得 2026-05-18 07:42:07
- API 入門 — Web API(REST / GraphQL / gRPC / 2026-05-18 07:42:07
- インストール(eclipseプラグイン) 2026-05-18 07:42:07
- Laravel「Dotenv values containing spaces must be surrounded 2026-05-18 07:42:07
- エラー一覧 2026-05-18 07:42:07
- curl: (51) SSL: certificate subject name '~' does not match 2026-05-18 07:42:07
- インストール方法(Windows版) 2026-05-18 07:42:07
- JSONから配列に変換 2026-05-18 07:42:07
- 処理を一定時間待つ 2026-05-18 07:42:07
- A non well formed numeric value encountered 2026-05-18 07:42:07
コメントを削除してもよろしいでしょうか?