ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|---|
|
CSRF とは
CSRF (Cross-Site Request Forgery / クロスサイトリクエストフォージェリ) は、悪意あるサイトがユーザのブラウザを利用して別サイトに無断でリクエストを送る攻撃。
例: ユーザが銀行サイトにログイン中、攻撃者のサイトを開くと、JavaScript が銀行 API に送金リクエストを送る → ログインクッキーが付くので成功してしまう。
対策: フォーム送信時にサーバ側が発行した秘密のトークンを併送し、トークン一致を検証。
Laravel の CSRF トークン埋め込み
Blade テンプレート
各 HTTP メソッド対応
{{ csrf_field() }}
{{ method_field("PUT") }}
Ajax / fetch / axios での CSRF トークン送信
方法 1: meta タグから読み取って X-CSRF-TOKEN ヘッダ
方法 2: フォームデータに含める
// FormData に含める
const formData = new FormData();
formData.append("_token", csrfToken);
formData.append("name", "Alice");
fetch("/users", { method: "POST", body: formData });
VerifyCsrfToken ミドルウェア
CSRF チェックは Laravel の web ミドルウェアグループに含まれる VerifyCsrfToken が自動で実行します:
// app/Http/Kernel.php
protected $middlewareGroups = [
"web" => [
// ...
\App\Http\Middleware\VerifyCsrfToken::class, // ← これ
// ...
],
];
// 内部の動作:
// 1. POST/PUT/PATCH/DELETE リクエストを検出
// 2. _token フィールド or X-CSRF-TOKEN ヘッダから値を取得
// 3. セッション内のトークンと一致するか検証
// 4. 不一致なら 419 (Page Expired) エラー
419 Page Expired エラー
CSRF トークンが無効な時のエラー。原因:
- @csrf / csrf_field() の付け忘れ: フォームに記述漏れ
- セッション期限切れ: フォームを開いてから長時間経過
- セッション cookie 設定ミス:
SESSION_DOMAIN/SESSION_SECURE_COOKIE等 - キャッシュ問題: ブラウザ・CDN キャッシュで古いトークン使用
- HTTPS 混在: HTTP と HTTPS のセッション分離
特定 URL を CSRF チェックから除外
外部 API からの Webhook 等、CSRF チェック不要な URL は除外可能:
// app/Http/Middleware/VerifyCsrfToken.php
class VerifyCsrfToken extends Middleware
{
protected $except = [
"stripe/*",
"webhook/*",
"api/external/payment-callback",
];
}
注意: 除外した URL は CSRF 攻撃に晒されます。代わりに別の認証(API トークン、署名検証)を使うこと。
API(Sanctum / Passport)の場合
SPA + Sanctum の場合は別の仕組み:
// 初回: /sanctum/csrf-cookie で XSRF-TOKEN cookie 取得
await axios.get("/sanctum/csrf-cookie");
// 以降は cookie + X-XSRF-TOKEN ヘッダで認証
await axios.post("/api/users", data);
// axios は自動で XSRF-TOKEN cookie を X-XSRF-TOKEN ヘッダに変換
トークンの取得方法
// Controller / その他 PHP コードから
$token = csrf_token();
// Blade
{{ csrf_token() }}
// Session から直接
session()->token()
セキュリティのベストプラクティス
- すべての POST/PUT/PATCH/DELETE に @csrf: 例外なし
- session.same_site = lax: CSRF 防御の追加層(config/session.php)
- HTTPS 必須: トークン盗聴防止
- session expire 短め: 漏洩リスク軽減
- Origin / Referer ヘッダ確認: 追加防御
- SameSite=Strict: より厳格な防御(UX 影響あり)
関連記事
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子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
コメントを削除してもよろしいでしょうか?