ホームページ  >  記事  >  バックエンド開発  >  複数の PHP フォーム配信を防止する

複数の PHP フォーム配信を防止する

WBOY
WBOYオリジナル
2016-06-13 13:07:05932ブラウズ

複数の PHP フォーム送信を防止します

HTML フォームを送信する場合、フォームが正常に送信されて応答ページが表示されるまでに数秒かかる場合があります。アイドル状態になって送信ボタンを何度もクリックしてしまうと、フォームの送信が重複してしまう可能性があります。通常は実際には問題になりませんが、場合によっては、この問題が発生するのを防ぎたい場合があります。
以下に、重複送信を防ぐための 2 つの簡単なヒントを示します。これらを使用することも、両方を組み合わせて使用​​することもできます。

?JavaScript

を使用した複数のフォーム送信を防止します。

Javascript ブロックを使用して送信を繰り返すのが、おそらく最も簡単な方法です。誰かがフォームを送信するときは、単純に送信ボタンを無効にし、その値を「送信してください。お待ちください...」など、よりわかりやすいものに変更することもあります。

たとえば、このボタンをクリックしてみてください。このページをリロードするまで無効のままになります:

最初のステップは、送信ボタンに一意の ID (例: id="myButton":

) を与えることです。
<input type="submit" value="Submit" id="myButton" />

2 番目 (最後の) ステップは、2 つの Javascript コマンドに

のタグを付けることです。 1 つ目は、フォームの送信後に送信ボタンを無効にするようにブラウザーに指示し、2 つ目は、何が起こっているのかユーザーにわかるようにボタンのテキストを変更します。これはフォームタグに追加するコードです:

onsubmit="document.getElementById('myButton').disabled=true;
document.getElementById('myButton').value='Submitting, please wait...';"

フォームのマークアップは次のようになります:


それでおしまい。この方法は、ほとんどのブラウザ (IE+、FireFox、Opera など) で機能します。

?複数のフォーム送信で Cookie が使用されないようにします

ブラウザー セッション全体 (またはそれ以上) で繰り返し送信されることを避けたい場合は、Cookie の使用を検討してください。たとえば、独自のフォーム処理スクリプトを編集するブラウザは、フォームの処理後、HTML またはリダイレクト プリントヘッドが処理される前に Cookie を送信します。このコードを mail() コマンドの後に置くと、ほとんどの場合機能するはずです:

setcookie('FormSubmitted', '1');

然后在处理之前检查cookie。如果有这个访问者已经提交了表单在活跃的浏览器会话。将下列代码添加到窗体的开始处理脚本:

if (isset($_COOKIE['FormSubmitted'])
{
    die('You may only submit this form once per session!');
}

就是这样!
如果修改,以阻止重复提交与cookies。注意:在上面的脚本和cookie的打印代码调用后添加一些代码的mail()函数:

<?php
<span style="color:red">/* Prevent duplicate submissions */
if (isset($_COOKIE['FormSubmitted'])
{
    show_error('You may only submit this form once per session!');
}</span>

/* Set e-mail recipient */
$myemail  = "you@domain.com";

/* Check all form inputs using check_input function */
$yourname = check_input($_POST['yourname'], "Enter your name");
$subject  = check_input($_POST['subject'], "Write a subject");
$email    = check_input($_POST['email']);
$website  = check_input($_POST['website']);
$likeit   = check_input($_POST['likeit']);
$how_find = check_input($_POST['how']);
$comments = check_input($_POST['comments'], "Write your comments");
//www.software8.co 原文
/* If e-mail is not valid show error message */
if (!preg_match("/([\w\-]&#43;\@[\w\-]&#43;\.[\w\-]&#43;)/", $email))
{
    show_error("E-mail address not valid");
}

/* If URL is not valid set $website to empty */
if (!preg_match("/^(https?:\/\/&#43;[\w\-]&#43;\.[\w\-]&#43;)/i", $website))
{
    $website = '';
}

/* Let's prepare the message for the e-mail */
$message = "Hello!

Your contact form has been submitted by:

Name: $yourname
E-mail: $email
URL: $website

Like the website? $likeit
How did he/she find it? $how_find

Comments:
$comments

End of message
";

/* Send the message using mail() function */
mail($myemail, $subject, $message);

<span style="color:red">/* Set a cookie to prevent duplicate submissions */
setcookie('FormSubmitted', '1');</span>

/* Redirect visitor to the thank you page */
header('Location: thanks.htm');
exit();

/* Functions we used */
function check_input($data, $problem='')
{
    $data = trim($data);
    $data = stripslashes($data);
    $data = htmlspecialchars($data);
    if ($problem && strlen($data) == 0)
    {
        show_error($problem);
    }
    return $data;
}

function show_error($myError)
{
?>
    <html>
    <body>

    <b>Please correct the following error:</b><br />
    <?php echo $myError; ?>

    </body>
    </html>
<?php
exit();
}
?
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。