PHP

Laravelの二重送信対策

動作環境

  • Laravel 8.40.0
  • PHP 8.0.3
  • macOS 12.0.1
  • CentOS Linux release 7.8.2003 (Core)でも検証済み

登録フォームなどで意図しないリクエストにより複数回フォームが送信され重複したデータが保存される場合があります。

その対策方法をまとめます。

重複したリクエストが発生するケースとして以下のケースが考えられるかと思います。

二重送信となるケース

  • フォームのサブミットボタンをダブルクリックする
  • フォーム送信後、戻るボタンでフォームに戻り再度サブミットボタンをクリックする
  • フォーム送信後の完了ページでリロードする

対策方法

コントローラーのstoreメソッドなどのpostデータがデータベースに保存される際に以下のコードを記載する。

$request->session()->regenerateToken();

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Models\Answer;

class AnswersController extends Controller
{
    public function store(Request $request)
    {
        $answer = new Answer();
        $answer->answer = $request->answer;
        $answer->save();

        // 二重送信防止
        $request->session()->regenerateToken();

        return view('answers/success');
    }
}

この対策を行うと、二重送信がされた際には419エラーが返され、データの重複登録などが発生しないようになります。

  • この記事を書いた人

コウダイ

文系・ノースキル・完全未経験・アラサー・地方住み・残業100時間超えの社畜ホテルマンから都内上場IT企業のフルリモートWebエンジニアに転職した人。

都内上場IT企業に勤務するWebエンジニア5年目|プログラミングスクールのテックキャンプ公式アンバサダー|新卒で手取り18万の地方ホテルマン6年→プログラミングを900時間勉強→転職活動100社以上応募→アラサー未経験から7ヶ月でフルリモートのWebエンジニアに転職し年収100万円UP|33歳2児のパパ|ブログ歴4年→月間6,000PV|エンジニア転職ノウハウ、プログラミング、Web制作、副業での稼ぎ方など、「時間や場所に縛られずに稼ぐ」方法を発信しています。

-PHP