PHP+Sessionを利用したフォームの重複送信を防止する手順を詳しく解説

php中世界最好的语言
リリース: 2023-03-26 08:16:01
オリジナル
2428 人が閲覧しました

今回は、PHP+Sessionでフォームの重複送信を防ぐための手順について詳しく説明します。PHP+Sessionがフォームの重複送信を防ぐために使用すべき注意点とは何ですか。 、見てみましょう。

index.php

現在のフォームページの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が更新された場合は、それ以外の値を設定しますコードが実行されます

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();session_start();

2. 如果有表单提交

代码如下 复制代码

if (isset($token))

2. フォーム送信がある場合

コードは次のとおりです

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 "已提交";  
}
ログイン後にコピー
この記事の事例を読んだ後、さらに興味深い情報を入手してください。php 中国語 Web サイトの他の関連記事にも注目してください。

推奨書籍:

PHP で大きなファイルをカットおよびマージする手順の詳細な説明


PHP+mongoDB データベース操作手順の詳細

php 中国語 Web サイトの学習トピック

:
php セッション🎜 (写真とテキストを含む)、ビデオ、ケース)🎜🎜

以上がPHP+Sessionを利用したフォームの重複送信を防止する手順を詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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