この記事では、PHP のフォームの繰り返し送信を防止する機能を主に紹介し、トークンの検証に基づいてフォームの繰り返し送信を防ぐための PHP の関連操作テクニックを分析します。非常に簡単で実用的です。 .
この記事の例では、フォームの重複送信を防止する機能を PHP で実装します。ご参考までに、以下のように共有します:
フォームの繰り返し送信を防ぐ方法はたくさんありますが、今日は PHP でフォームの繰り返し送信を効果的に防ぐ方法を紹介します。
コードはとてもシンプルです
小さなデモを共有するのは非常に賢いと思います。そこから学ぶことができます:
特定のコード:
<?php /* * 2016年9月29日08:09:13 */ session_start(); header("Content-Type: text/html;charset=utf-8"); function set_token() { $_SESSION['token'] = md5(microtime(true)); } function valid_token() { $return = $_REQUEST['token'] === $_SESSION['token'] ? true : false; set_token(); return $return; } //如果token为空则生成一个token if(!isset($_SESSION['token']) || $_SESSION['token']=='') { set_token(); } if(isset($_POST['web'])){ if(!valid_token()){ echo "token error,请不要重复提交!"; }else{ echo '成功提交,Value:'.$_POST['web']; } }else{ ?> <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"> <title>PHP防止重复提交表单</title> <meta name="keywords" content="PHP" /> <meta name="description" content="PHP防止重复提交表单" /> </head> <body> <p id="main"> <p class="demo"> <form method="post" action=""> <input type="hidden" name="token" value="<?php echo $_SESSION['token']?>"> <input type="text" class="input" name="web" value="脚本之家"> <input type="submit" class="btn" value="提交" /> </form> </p> </p> </body> </html> <?php }?>
この記事は以上です。お読みいただきありがとうございます。詳細については、PHP 中国語 Web サイトを参照してください。
関連する推奨事項:
PHP は、CURL を介してファイルをアップロードする機能を実装します
tp フレームワーク (thinkPHP) は、ログイン パスワードが 3 回間違った場合のアカウント ロック機能を実装します
PHP は、データ ディクショナリを生成する機能を実装します
以上がPHPはフォームの重複送信を防止する機能を実装(トークン検証による)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。