PHP防止表單重復提交的解決方法


 

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>密 &nbsp; 碼:<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['submit'])) { 
    if ($_SESSION['is_submit'] == '0') { 
        $_SESSION['is_submit'] = '1'; 
        echo "代碼塊,要做的事,代碼...<a onclick='history.go(-1);' href='javascript:void(0)'>返回</a>"; 
    } else { 
        echo "請不用重復提交<a href='index.php'>PHP+SESSION防止表單重復提交</a>"; 
    } 
}




 

php 解決表單重復提交實現方法介紹

 

[導讀] 重復提交是我們開發中會常碰到的一個問題,除了我們使用js來防止表單的重復提交,同時還可以使用php來防止重復提交哦。例1 代碼如下復制代碼

重復提交是我們開發中會常碰到的一個問題,除了我們使用js來防止表單的重復提交,同時還可以使用php來防止重復提交哦。

例1

 代碼如下 復制代碼

<?php
/*
 * php中如何防止表單的重復提交
 */
session_start();
if (empty($_SESSION['ip'])) {//第一次寫入操作,判斷是否記錄了IP地址,以此知道是否要寫入數據庫
    $_SESSION['ip'] = $_SERVER['REMOTE_ADDR']; //第一次寫入,為后面刷新或后退的判斷做個鋪墊
    //...........//寫入數據庫操作
} else {//已經有第一次寫入后的操作,也就不再寫入數據庫
    echo '請不要再次刷新和后退'; //寫一些已經寫入的提示或其它東西
}
?>


具體原理

session范圍變量token來防止。

1. 開啟session:

session_start();

2. 如果有表單提交

 代碼如下 復制代碼

if (isset($token))


token以hidden的形式包含在form當中。

 代碼如下 復制代碼

<input type="hidden" name="token" value="<?php echo $token; ?>" />

 
3. 如果是重復提交表單

 代碼如下 復制代碼

1.if ($_SESSION["token"] != $token) { 
2.    // 不讓重復提交,在此處理 
3.    // header("location:".$_SERVER['PHP_SELF']); 
4.} else { 
5.    // 正常的表單提交,在此處理 
6.    // echo "已提交";    
7.}

4. 設置token值

 代碼如下 復制代碼

1.$token = mt_rand(0,1000000); 
2.$_SESSION['token'] = $token;

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM