カテゴリ: Laravel 更新日: 2026/03/01

LaravelのCSRFトークンとは?フォームのセキュリティ対策

LaravelのCSRFトークンとは?フォームのセキュリティ対策
LaravelのCSRFトークンとは?フォームのセキュリティ対策

先生と生徒の会話形式で理解しよう

生徒

「先生、Laravelでフォームを作るときによく@csrfって書きますけど、これは何ですか?」

先生

「これはCSRFトークンと呼ばれるもので、フォームを安全に送信するための仕組みです。」

生徒

「CSRFってなんですか?」

先生

「CSRFはクロスサイトリクエストフォージェリの略で、悪意のある第三者があなたのサイトに不正なリクエストを送る攻撃のことです。例えば、ログインした状態のサイトで勝手に操作されてしまうリスクがあります。」

生徒

「なるほど、安全にフォームを送るための仕組みなんですね。」

1. CSRFトークンの基本

1. CSRFトークンの基本
1. CSRFトークンの基本

LaravelでWebアプリケーションを作る際、セキュリティの要となるのが「CSRFトークン」です。これは、自分のサイトのフォームから送られたデータが、本当に自分のサイト内の画面から送信されたものかを証明するための「秘密の合言葉」のような役割を果たします。

プログラミングが初めての方でも、まずは「外部からの不正ななりすまし操作を防ぐためのスタンプ」だとイメージすれば分かりやすいでしょう。Laravelでは、フォームの中に@csrfという短い1行を書くだけで、この高度なセキュリティ機能が有効になります。

例えば、@csrfを記述したファイルがブラウザで表示されると、自動的に以下のような隠し入力フィールドが生成されます。


<input type="hidden" name="_token" value="a1b2c3d4e5f6g7h8i9j0k1l2m3n4o5p6q7r8s9t0">

このように、目には見えない場所で「a1b2c3...」といった複雑でランダムな文字列(トークン)が発行されます。ユーザーが送信ボタンを押すと、このトークンも一緒にサーバーへ送られます。サーバー側では「今、自分が発行した合言葉と同じかな?」と一瞬で照合を行い、一致した場合のみ処理を受け付けます。これにより、悪意のある第三者が勝手に外部からデータを送りつけようとしても、正しい合言葉を知らないため、システムが自動的にブロックしてくれる仕組みです。

2. Bladeでのフォーム作成とCSRFトークン

2. Bladeでのフォーム作成とCSRFトークン
2. Bladeでのフォーム作成とCSRFトークン

フォームを作る際には、resources/viewsにBladeテンプレートを作ります。例えばお問い合わせフォームの場合:


<form action="/contact" method="POST">
    @csrf
    <div>
        <label for="name">名前:</label>
        <input type="text" id="name" name="name">
    </div>
    <div>
        <label for="email">メールアドレス:</label>
        <input type="email" id="email" name="email">
    </div>
    <button type="submit">送信</button>
</form>

ここで@csrfを入れることで、フォームに隠しフィールドとしてCSRFトークンが含まれ、送信時にサーバー側で自動チェックされます。

3. CSRFトークンの仕組み

3. CSRFトークンの仕組み
3. CSRFトークンの仕組み

CSRFトークンはランダムな文字列で、ユーザーのセッションと紐付けられています。フォーム送信時にサーバーがこのトークンとセッション内の値を照合し、一致すれば正しいリクエストとして処理します。これにより、第三者が不正にフォームを送信しても弾かれる仕組みです。

4. CSRFトークンを手動で確認する方法

4. CSRFトークンを手動で確認する方法
4. CSRFトークンを手動で確認する方法

通常は@csrfで自動的にチェックされますが、APIやAjaxリクエストでトークンを手動で扱うこともあります。metaタグにトークンを埋め込み、JavaScriptで取得してリクエストヘッダーに追加する方法です。


<meta name="csrf-token" content="{{ csrf_token() }}">

<script>
    const token = document.querySelector('meta[name="csrf-token"]').getAttribute('content');
    fetch('/contact', {
        method: 'POST',
        headers: {
            'X-CSRF-TOKEN': token,
            'Content-Type': 'application/json'
        },
        body: JSON.stringify({ name: '太郎', email: 'taro@example.com' })
    });
</script>

5. CSRF対策のポイント

5. CSRF対策のポイント
5. CSRF対策のポイント
  • すべてのフォームに@csrfを必ず追加する
  • AjaxやJavaScriptで送信する場合は、ヘッダーにCSRFトークンをセットする
  • トークンはユーザーごとにランダムで生成されるため、使い回さない
  • POST以外のPUT、PATCH、DELETEリクエストでも@csrfが必要

これらを守ることで、Laravelのフォームを安全に運用でき、ユーザーの情報を守ることができます。

カテゴリの一覧へ
新着記事
New1
Symfony
Symfonyのルーティングの基本を完全ガイド!YAML・PHP・アノテーションの違いもわかりやすく解説
New2
Laravel
LaravelでAPIのレスポンスをテストする方法を完全解説!assertJsonで初心者も安心
New3
CodeIgniter
CodeIgniterでRESTful API開発!初心者でもわかる全体構成ガイド
New4
Symfony
Symfonyのコントローラとは?作成・構造・役割を初心者向けにやさしく解説!
人気記事
No.1
Java&Spring記事人気No1
Laravel
Laravelのシングルアクションコントローラとは?使い方と利点
No.2
Java&Spring記事人気No2
Laravel
Laravelで動的パラメータをルートに渡す方法!初心者にもやさしいルートパラメータの使い方入門
No.3
Java&Spring記事人気No3
Laravel
Laravelでキャッシュを使う方法(ファイル・Redis・Memcached)
No.4
Java&Spring記事人気No4
Symfony
Symfonyの依存性注入(DI)とは?コンストラクタでの注入方法を初心者向けに徹底解説
No.5
Java&Spring記事人気No5
Laravel
Laravelで名前付きルートを設定する方法!初心者でもわかるroute()関数の使い方
No.6
Java&Spring記事人気No6
Laravel
LaravelのBlade構文まとめ!@if @foreach など基本ディレクティブ解説
No.7
Java&Spring記事人気No7
Laravel
Laravelのマイグレーション履歴を確認する方法を徹底解説!migrate:statusの使い方
No.8
Java&Spring記事人気No8
Laravel
Laravelでコントローラを作成する方法(artisanコマンド)