この内容は古いバージョンです。最新バージョンを表示するには、戻るボタンを押してください。
バージョン:3
ページ更新者:guest
更新日時:2026-06-11 07:07:02

タイトル: ログイン、ユーザー登録、パスワードリセット後のリダイレクト先の変更方法
SEOタイトル: Laravel 認証後のリダイレクト先を変更する方法(Breeze / Fortify / Jetstream / 旧 UI 対応)

この記事の要点
  • Laravel 6 系まで: LoginController::$redirectTo / RegisterController::$redirectTo / ResetsPasswordsController::$redirectTo を上書き
  • Laravel 8+ Fortify / Jetstream / Breeze: app/Providers/RouteServiceProvider.phpHOME 定数を変更するのが最短
  • Fortify の場合は config/fortify.phphome でも可。さらに細かい制御は app/Actions/Fortify/... のリダイレクトレスポンサを差し替え
  • 動的に振り分けたいときは authenticated() メソッドをオーバーライド(管理者は /admin、一般は /dashboard 等)
  • 意図した URL に戻したい場合は redirect()->intended("/home") を活用(ログイン前の URL を覚えている)

変更すべき箇所はバージョンと足回りで異なる

環境変更箇所
Laravel 6 / 7(laravel/ui 同梱の旧 UI)App\Http\Controllers\Auth\LoginController::$redirectTo
Laravel 8+ Breezeapp/Providers/RouteServiceProvider.phpHOME 定数
Laravel 8+ Fortify / Jetstreamconfig/fortify.phphome または 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 へ。