程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> php通過記錄IP來防止表單重復提交方法分析

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

編輯:PHP綜合

本文實例分析了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程序設計有所幫助。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved