當前位置:首頁 » 編程語言 » php重復提交

php重復提交

發布時間: 2022-06-12 21:14:46

『壹』 php通過記錄IP來防止表單重復提交方法分析

本文實例分析了php通過記錄IP來防止表單重復提交方法。分享給大家供大家參考。具體分析如下:
這個原理比較的簡單就是用戶第一次提交時我們記錄提交用戶的IP地址,這樣如果用戶在固定時間內再次提交表單就會提示重復提交了,這種做法通常用於在頂一下,支持一下這種應用中了,在防止數據重復提交是一個非常不好的選擇.
例子,代碼如下:
復制代碼
代碼如下:<?php
session_start();
if(empty($_SESSION['ip']))//第一次寫入操作,判斷是否記錄了IP地址,以此知道是否要寫入資料庫
{
$_SESSION['ip']=$_SERVER['REMOTE_ADDR'];//第一次寫入,為後面刷新或後退的判斷做個鋪墊
mysql_query("INSERT
INTO
admin(id,
name,
age)
VALUES(123,
'姚明',
25)");//寫入資料庫操作
}
else//已經有第一次寫入後的操作,也就不再寫入資料庫
{
echo
'請不要重復提交表單或刷新頁面';//寫一些已經寫入的提示或其它東西
}
?>
還有辦法就是:
1:在頁面生成隨機碼,也就是每次提交隨機碼都不一樣,在提交的時候驗證隨機碼!
2:在提交的時候,驗證如果數據存在,就不提交了.
如果你想防止重復提交入庫IP不是最好的辦法,我們可以在資料庫中查詢是不是有相同記錄並且IP是不是想同再進行處理.
例子,代碼如下:
復制代碼
代碼如下:$sql
="select
*
from
表名
where
buy_tel='電話'
and
IP='$ip'
";//
and
$time-buy_date<60
$query
=
$db->query(
$sql
);
if(
$db->rows(
$query
)
)
{
echo('<script>alert("您己提交過了,請勿重復提交!");</script>');
}
else
{
//進行入庫操作
}
希望本文所述對大家的PHP程序設計有所幫助。

『貳』 PHP如何防止form重復提交

1. 使用JS讓按鈕在點擊一次後禁用(disable)。採用這種方法可以防止多次點擊的發生,實現方式較簡單。

缺點是若客戶端禁止JavaScript腳本,則失效。

2. 在提交成功後執行頁面重定向(redirect)。轉到提交成功信息頁面。

特點:避免F5重復提交,消除瀏覽器前進和後退按鈕可導致的同樣問題。

3. 表單隱藏域中存放session(表單被請求時生成的標記)。採用此方法在接收表單數據後,檢查此標志值是否存在,先進行刪除,然後處理數據; 若不存在,說明已提交過,忽略本次提交。

//服務端生成隨機數存入session,分配至表單頁
$data['sess_id']=$_SESSION['sid']=mt_rand(1000,9999);
$this->load->view('form',$data);

//表單頁隱藏域存放此session值
<inputtype="hidden"name="sid"value="<?=$sess_id;?>">

//處理
if($_POST['sid']!=''&&$_POST['sid']==$_SESSION['sid'])
{
unset($_SESSION['sid']);

echo'處理數據';
}
else
{
echo'已提交過表單';
}

4. 資料庫唯一索引約束(最有效的防止重復數據的方法)。

5. 使用驗證碼

『叄』 如何真正解決表單重復提交問題php代碼

在表單中添加一個隱藏域token,就是個隨機數,由php生成,同時保存在session中;當表單提交時,比對token和session中存儲的值是否一樣,如果一致則通過,清除session中的保存的token;不一致則不通過

『肆』 php如何防止重復提交

您可以加上表單令牌,或者使用隨機數的方式來阻止

『伍』 PHP 怎麼防止GET方式提交重復數據

PHP 防止表單重復提交,使用令牌來做驗證,即可解決。示例如下:

index.php:

<?php
header("Content-type:text/html;charset=utf-8");
//開啟session
session_start();

//如果令牌為空,則生成一個令牌
if(!isset($_SESSION['token'])||$_SESSION['token']==""){
//給當前表單生成一個令牌
$_SESSION['token']=md5(microtime(true));
}
?>
<formmethod="get"action="deal.php">
名稱:<inputtype="text"name="names"><br/>
描述:<inputtype="text"name="desc"><br/>
<inputtype="text"name="token"value="<?=$_SESSION['token']?>">
<inputtype="submit"value="提交">
</form>

deal.php:

<?php
header("Content-type:text/html;charset=utf-8");
//開啟session
session_start();
//驗證令牌
if($_REQUEST['token']===$_SESSION['token']){
//表單已經提交,重新生成令牌
$_SESSION['token']=md5(microtime(true));
echo"表單提交成功:<br/>";
print_r($_REQUEST);
}else{
echo"重復提交";
}
?>
熱點內容
sqlserver連接驅動 發布:2024-05-06 00:33:34 瀏覽:645
存儲開銷 發布:2024-05-06 00:13:38 瀏覽:953
伺服器怎麼盈利 發布:2024-05-05 23:56:16 瀏覽:941
java網站培訓學校 發布:2024-05-05 23:43:11 瀏覽:40
淘寶搜索演算法 發布:2024-05-05 23:37:07 瀏覽:998
sqlwhencasethen 發布:2024-05-05 23:27:51 瀏覽:641
模架編程軟體 發布:2024-05-05 23:26:54 瀏覽:483
存儲過程異常 發布:2024-05-05 23:24:03 瀏覽:399
winxp訪問不了win7 發布:2024-05-05 23:05:23 瀏覽:734
演算法牛 發布:2024-05-05 22:43:40 瀏覽:720