溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

php防止表單重復(fù)提交的方法

發(fā)布時(shí)間:2021-02-22 15:38:04 來源:億速云 閱讀:151 作者:清風(fēng) 欄目:編程語言

這篇文章主要為大家展示了php防止表單重復(fù)提交的方法,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶大家一起來研究并學(xué)習(xí)一下“php防止表單重復(fù)提交的方法”這篇文章吧。

php有什么用

php是一個(gè)嵌套的縮寫名稱,指的是英文超級(jí)文本預(yù)處理語言(php:Hypertext Preprocessor)的縮寫,它的語法混合了C、Java、Perl以及php自創(chuàng)新的語法,主要用來做網(wǎng)站開發(fā),許多小型網(wǎng)站都用php開發(fā),因?yàn)閜hp是開源的,從而使得php經(jīng)久不衰。

用戶提交表單時(shí)可能因?yàn)榫W(wǎng)速的原因,或者網(wǎng)頁被惡意刷新,致使同一條記錄重復(fù)插入到數(shù)據(jù)庫中,這是一個(gè)比較棘手的問題。我們可以從客戶端和服務(wù)器端一起著手,設(shè)法避免同一表單的重復(fù)提交。

1.使用客戶端腳本

<form method="post" name="register" action="test.php" enctype="multipart/form-data">
<input name="text" type="text" id="text" />
<input name="cont" value="提交" type="button" onClick="document.register.cont.value='正在提交,請(qǐng)等待...';document.register.cont.disabled=true;document.the_form.submit();">
</form>

當(dāng)用戶單擊“提交”按鈕后,該按鈕將變?yōu)榛疑豢捎脿顟B(tài)
上面的例子中使用OnClick事件檢測(cè)用戶的提交狀態(tài),如果單擊了“提交”按鈕,該按鈕立即置為失效狀態(tài),用戶不能單擊按鈕再次提交。

還有一個(gè)方法,也是利用JavaScript的功能,但是使用的是OnSubmit()方法,如果已經(jīng)提交過一次表單,將立即彈出對(duì)話框,代碼如下:

<script language="javascript">
var submitcount=0;
function submitOnce (form){
    if (submitcount == 0){
         submitcount++;
         return true;
    } else{
        alert("正在操作,請(qǐng)不要重復(fù)提交,謝謝!");
        return false;
    }
}
</script>
<form name="the_form" method="post" action="" onSubmit="return submitOnce(this)">
<input name="text" type="text" id="text" />
<input name="cont" value="提交" type="submit">
</form>

在上例中,如果用戶已經(jīng)單擊“提交”按鈕,該腳本會(huì)自動(dòng)記錄當(dāng)前的狀態(tài),并將submitcount變量自加1,當(dāng)用戶試圖再次提交時(shí),腳本判斷submitcount變量值非零,提示用戶已經(jīng)提交,從而避免重復(fù)提交表單。

2. 使用session(這個(gè)與JSP處理方法是一樣的)

利用PHP的Session功能,也能避免重復(fù)提交表單。Session保存在服務(wù)器端,在PHP運(yùn)行過程中可以改變Session變量,下次訪問這個(gè)變量時(shí),得到的是新賦的值,所以,可以用一個(gè)Session變量記錄表單提交的值,如果不匹配,則認(rèn)為是用戶在重復(fù)提交。
A頁面的代碼:

<?php
session_start();                //根據(jù)當(dāng)前SESSION生成隨機(jī)數(shù)
$code = mt_rand(0,1000000);
$_SESSION['code'] = $code;      //將此隨機(jī)數(shù)暫存入到session
?>
<form id="form1" name="form1" method="post" action="t2.php">
    <p>說明 <input type="text" name="titile" />
        <input type="hidden" name="originator" value="<?php echo $code;?>"></p>
    <p><input type="submit" name="Submit" value="提交" /></p>
</form>

B頁面:

<?php
session_start();
if(isset($_POST['originator'])) {
    if($_POST['originator'] == $_SESSION['code']){
        echo "ok";
        unset($_SESSION["code"]);               //將其清除掉此時(shí)再按F5則無效
    }else{
        echo "請(qǐng)不要刷新本頁面或重復(fù)提交表單";
    }
}?>

以上就是關(guān)于“php防止表單重復(fù)提交的方法”的內(nèi)容,如果改文章對(duì)你有所幫助并覺得寫得不錯(cuò),勞請(qǐng)分享給你的好友一起學(xué)習(xí)新知識(shí),若想了解更多相關(guān)知識(shí)內(nèi)容,請(qǐng)多多關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

php
AI