ホームページ >バックエンド開発 >PHPチュートリアル >PHPでフォームの重複送信を防止する機能を実装【トークン検証による】
この記事では、主に PHP のフォームの重複送信を防止する機能を紹介し、フォームの重複送信を防止するための PHP の関連操作テクニックを分析します。非常にシンプルで実用的です。 it
この記事の例では、フォームの繰り返し送信を防止する機能を 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 }?>
tp フレームワーク (thinkPHP) ) 3回ログインを実現 パスワード間違い時にアカウントをロックする機能の例
CodeIgniter フレームワーク データベースの基本操作関連説明
##
以上がPHPでフォームの重複送信を防止する機能を実装【トークン検証による】の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。