ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
通常のリダイレクト
Laravel での通常のリダイレクトは Controller のメソッド戻り値として使います:
class HomeController extends Controller {
public function show() {
if (!auth()->check()) {
return redirect('/login'); // ← Controller が return して初めて効く
}
return view('home');
}
}
しかしリダイレクトしたい判定がもっと深いレイヤー(Service / Repository / static helper / Middleware 自体)にあるケースでは、戻り値を return で伝搬させるのが面倒です。
対処1: throwResponse() で例外として送出
Laravel の Response オブジェクトは throwResponse() メソッドで HttpResponseException を投げます。これはハンドラがキャッチして適切なレスポンスとして返却します:
namespace App\Services;
class PaymentService {
public static function processPayment($order) {
if ($order->isAlreadyPaid()) {
// どこからでもリダイレクト可
redirect('/orders/' . $order->id)
->with('error', 'すでに支払済みです')
->throwResponse();
}
// ... 通常処理
}
}
// 呼び出し側はリダイレクトを意識する必要がない
class OrderController extends Controller {
public function pay($id) {
$order = Order::findOrFail($id);
PaymentService::processPayment($order); // ← ここでリダイレクトが投げられる
return view('payment.complete');
}
}
throwResponse() は例外として処理を即座に止めてレスポンスを返すため、return の伝播が不要。Controller の戻り値処理を書く必要がありません。
対処2: abort_redirect() / abort()
Laravel には専用ヘルパーが用意されています:
// 直接リダイレクトを投げる
abort_redirect('/login'); // 302 リダイレクト
abort_redirect('/forbidden', 403); // 任意のステータスコード
// HTTP エラーで停止(ハンドラがエラーページに飛ばす)
abort(404);
abort(403, '権限がありません');
// 条件付き
abort_if(!$user->canAccess($resource), 403);
abort_unless($user->isAdmin(), 403, '管理者のみ');
abort() は HttpException を投げるので、これも例外ベース。エラーページに飛ばす場合に最適です。
対処3: Middleware でリダイレクト返却(推奨)
そもそもリダイレクトロジックはMiddleware に切り出すのが Laravel 流の綺麗な書き方:
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Request;
class EnsurePaymentNotYetMade {
public function handle(Request $request, Closure $next) {
$order = $request->route('order');
if ($order && $order->isAlreadyPaid()) {
return redirect()->route('orders.show', $order)
->with('error', 'すでに支払済みです');
}
return $next($request);
}
}
// routes/web.php
Route::post('/orders/{order}/pay', [OrderController::class, 'pay'])
->middleware(EnsurePaymentNotYetMade::class);
responsable インターフェイス(Laravel 5.5+)
カスタムオブジェクトを直接 return して、変換ロジックで Response にする方法もあります:
namespace App\Responses;
use Illuminate\Contracts\Support\Responsable;
class RedirectToLogin implements Responsable {
public function toResponse($request) {
return redirect('/login')->with('error', 'ログインが必要です');
}
}
// Controller / Service / どこでも
return new RedirectToLogin(); // フレームワークが Response に変換
各方式の使い分け
| シーン | 推奨方式 |
|---|---|
| Service / Repository の中で条件分岐が深い | throwResponse()(例外で即停止) |
| 権限・認証エラー | abort(403) / abort_if |
| 共通の事前チェック | Middleware(責務分離が綺麗) |
| カスタムレスポンスを使い回す | Responsable インターフェイス |
| Controller 内 | 普通に return redirect() |
注意点
- throwResponse は例外を投げるのでスタックトレースに残る → ログレベル設定に注意
- テストでの確認:
$response->assertRedirect('/login')でリダイレクト先を検証 - 多用は禁物: throwResponse / abort は便利だが、コードの流れが追いにくくなる → 可能なら Middleware を優先
- HTMX / Ajax では
HX-Redirectヘッダ等の対応も必要なケースあり
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子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
コメントを削除してもよろしいでしょうか?