ホームページ > バックエンド開発 > PHPチュートリアル > PHPでフォームの重複送信を防止する機能を実装【トークン検証による】

PHPでフォームの重複送信を防止する機能を実装【トークン検証による】

jacklove
リリース: 2023-04-01 17:46:02
オリジナル
1429 人が閲覧しました

この記事では、主に 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[&#39;token&#39;] = md5(microtime(true));
}
function valid_token() {
  $return = $_REQUEST[&#39;token&#39;] === $_SESSION[&#39;token&#39;] ? true : false;
  set_token();
  return $return;
}
//如果token为空则生成一个token
if(!isset($_SESSION[&#39;token&#39;]) || $_SESSION[&#39;token&#39;]==&#39;&#39;) {
  set_token();
}
if(isset($_POST[&#39;web&#39;])){
  if(!valid_token()){
    echo "token error,请不要重复提交!";
  }else{
    echo &#39;成功提交,Value:&#39;.$_POST[&#39;web&#39;];
  }
}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[&#39;token&#39;]?>">
      <input type="text" class="input" name="web" value="脚本之家">
      <input type="submit" class="btn" value="提交" />
    </form>
  </p>
</p>
</body>
</html>
<?php }?>
ログイン後にコピー

興味のある記事:

tp フレームワーク (thinkPHP) ) 3回ログインを実現 パスワード間違い時にアカウントをロックする機能の例

PHPでのデータディクショナリ生成機能の例

CodeIgniter フレームワーク データベースの基本操作関連説明

##

以上がPHPでフォームの重複送信を防止する機能を実装【トークン検証による】の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート