PHP でのフォーム送信中の複数の挿入の防止
フォームを設計するときは、ユーザーが誤ってまたは意図的に同じデータを複数回送信しないようにすることが重要です。回。これにより、データの不整合やその他の問題が発生する可能性があります。 PHP では、これを実現するための効果的な方法がいくつかあります。
1.送信時にフォームの送信ボタンを無効にする
JavaScript を使用して、フォームの送信後にフォームの送信ボタンを無効にします。ただし、これは確実な解決策ではありません。ユーザーはボタンをクリックせずにフォームを送信でき、JavaScript が無効になっているユーザーは影響を受ける可能性があります。
2. PHP セッションを利用して送信時間を追跡する
現在のタイムスタンプを記録するセッション変数 ($_SESSION['posttimer']) を確立します。フォームの送信を処理する前に、この変数の存在を確認し、現在時刻とセッションのタイムスタンプの間に十分な時間差 (たとえば、2 秒) があるかどうかを確認してください。間隔が短すぎる場合、送信は重複とみなされます。
3.一意のトークンをフォームに組み込む
各 POST で一意のトークンを生成します。このトークンのセッション変数を作成し、フォームに埋め込みます。フォームが送信されると、トークンが再生成され、セッションに保存されているトークンと比較されます。一致しない場合、フォームは 2 回送信されており、無効とみなされます。
以上がPHP で複数のフォーム送信を防ぐにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。