- 相關(guān)推薦
php通過記錄IP來防止表單重復(fù)提交方法分析
本文實(shí)例分析了php通過記錄IP來防止表單重復(fù)提交方法,供大家參考。具體分析如下,更多消息請(qǐng)關(guān)注應(yīng)屆畢業(yè)生網(wǎng)!
這個(gè)原理比較的簡(jiǎn)單就是用戶第一次提交時(shí)我們記錄提交用戶的IP地址,這樣如果用戶在固定時(shí)間內(nèi)再次提交表單就會(huì)提示重復(fù)提交了,這種做法通常用于在頂一下,支持一下這種應(yīng)用中了,在防止數(shù)據(jù)重復(fù)提交是一個(gè)非常不好的選擇.
例子,代碼如下:
代碼如下:
?
<?php
session_start();
if(empty($_SESSION['ip']))//第一次寫入操作,判斷是否記錄了IP地址,以此知道是否要寫入數(shù)據(jù)庫(kù){$_SESSION['ip']=$_SERVER['REMOTE_ADDR'];//第一次寫入,為后面刷新或后退的判斷做個(gè)鋪墊mysql_query("INSERT INTO admin(id, name, age) VALUES(123, '姚明', 25)");//寫入數(shù)據(jù)庫(kù)操作}
else//已經(jīng)有第一次寫入后的操作,也就不再寫入數(shù)據(jù)庫(kù){echo '請(qǐng)不要重復(fù)提交表單或刷新頁(yè)面';//寫一些已經(jīng)寫入的提示或其它東西}
?>
還有辦法就是:
1:在頁(yè)面生成隨機(jī)碼,也就是每次提交隨機(jī)碼都不一樣,在提交的時(shí)候驗(yàn)證隨機(jī)碼!
2:在提交的時(shí)候,驗(yàn)證如果數(shù)據(jù)存在,就不提交了.如果你想防止重復(fù)提交入庫(kù)IP不是最好的辦法,我們可以在數(shù)據(jù)庫(kù)中查詢是不是有相同記錄并且IP是不是想同再進(jìn)行處理.
例子,代碼如下:
代碼如下:
?
$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("您己提交過了,請(qǐng)勿重復(fù)提交!");</script>');}
else
{
//進(jìn)行入庫(kù)操作
}
【php通過記錄IP來防止表單重復(fù)提交方法分析】相關(guān)文章:
如何實(shí)現(xiàn)php登陸表單提交CSRF及驗(yàn)證碼03-24
PHP中用CURL偽造IP來源的方法03-31
php防止SQL注入的方法分享03-30
PHP頁(yè)面漏洞分析的方法03-27
php防止SQL注入攻擊與XSS攻擊方法11-16
php如何獲得ip地址12-05
如何實(shí)現(xiàn)PHP獲取表單數(shù)據(jù)與HTML嵌入PHP腳本03-25