ホームページ > バックエンド開発 > PHPチュートリアル > フォームの繰り返し送信を防ぐために PHP でセッションを追加するための解決策

フォームの繰り返し送信を防ぐために PHP でセッションを追加するための解決策

不言
リリース: 2023-03-23 11:32:01
オリジナル
1232 人が閲覧しました

この記事では主にフォームの重複送信を防ぐための PHP+Session の解決策を紹介しますので、必要な方は参考にしてください

現在のフォームページは is_submit に設定されています。 0

 SESSION_START(); 
$_SESSION['is_submit'] = 0;
<form id="reg" action="post.php" method="post"> 
  <p>用户名:<input type="text" class="input" name="username" id="user"></p> 
  <p>密   码:<input type="password" class="input" name="password" id="pass"></p> 
  <p>E-mail:<input type="text" class="input" name="email" id="email"></p> 
  <p><input type="submit" name="submit" class="btn" value="提交注册"/></p> 
</form>
ログイン後にコピー

post.php

フォームが送信されたら、現在の 'is_submit を 1 に設定します。post.php が更新されると、else コードが実行されます

SESSION_START(); 
if (isset($_POST[&#39;submit&#39;])) { 
  if ($_SESSION[&#39;is_submit&#39;] == &#39;0&#39;) { 
    $_SESSION[&#39;is_submit&#39;] = &#39;1&#39;; 
    echo "代码块,要做的事,代码...<a onclick=&#39;history.go(-1);&#39; href=&#39;javascript:void(0)&#39;>返回</a>"; 
  } else { 
    echo "请不用重复提交<a href=&#39;index.php&#39;>PHP+SESSION防止表单重复提交</a>"; 
  } 
}
ログイン後にコピー

php フォームの重複送信問題を解決する実装方法の紹介 【はじめに】フォームの重複送信を防ぐためにjsを使う以外にも、phpを使ってフォームの重複送信を防ぐこともできます。繰り返しの提出を防ぎます。

例 1 コードは次のとおりです

重複送信は、開発中に頻繁に遭遇する問題です。js を使用してフォームの繰り返し送信を防ぐだけでなく、php を使用することもできます。


例1

コードは次のとおりです

<?php
 /*
 * php中如何防止表单的重复提交
 */
session_start();
 if (empty($_SESSION[&#39;ip&#39;])) {//第一次写入操作,判断是否记录了IP地址,以此知道是否要写入数据库
  $_SESSION[&#39;ip&#39;] = $_SERVER[&#39;REMOTE_ADDR&#39;]; //第一次写入,为后面刷新或后退的判断做个铺垫
  //...........//写入数据库操作
} else {//已经有第一次写入后的操作,也就不再写入数据库
  echo &#39;请不要再次刷新和后退&#39;; //写一些已经写入的提示或其它东西
}
 ?>
ログイン後にコピー

特定の原則

セッションスコープ変数トークンを阻止します。

1. セッションを開きます:

session_start();

2. フォーム送信がある場合session_start();

2. 如果有表单提交

代码如下 复制代码

if (isset($token))
コードは次のとおりです

if ($ token))

トークンは非表示のフォームに含まれています。

次のコードをコピーします

<input type="hidden" name="token" value="<?php echo $token; ?>" />
ログイン後にコピー

3. フォームが繰り返し送信される場合

コードは次のとおりです

if ($_SESSION["token"] != $token) { 
  // 不让重复提交,在此处理 
  // header("location:".$_SERVER[&#39;PHP_SELF&#39;]); 
 } else { 
  // 正常的表单提交,在此处理 
  // echo "已提交";  
}
ログイン後にコピー

4. トークンの値を設定します

コードは次のとおりです

$token = mt_rand(0,1000000);
$_SESSION[&#39;token&#39;] = $token;
ログイン後にコピー
関連する推奨事項: PHP データベース保存セッションPHP 入門セッション 🎜🎜phpセッション開発の原則と使用法の詳細な説明


以上がフォームの繰り返し送信を防ぐために PHP でセッションを追加するための解決策の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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