php防止網(wǎng)站被刷新的方法匯總
本文實例講述了php防止網(wǎng)站被刷新的方法。分享給大家供大家參考。具體方法如下:
對于像采用WP建設的站來說,頻繁的刷新會導致數(shù)據(jù)庫吃緊。下面附上一段代碼,防止頻繁的刷新造成的死機情況。
方法一,代碼如下:
session_start();
$k=$_GET['k'];
$t=$_GET['t'];
$allowTime = 1800;//防刷新時間
$ip = get_client_ip();
$allowT = md5($ip.$k.$t);
if(!isset($_SESSION[$allowT]))
{
$refresh = true;
$_SESSION[$allowT] = time();
}elseif(time() - $_SESSION[$allowT]>$allowTime){
$refresh = true;
$_SESSION[$allowT] = time();
}else{
$refresh = false;
}
?>
方法二,代碼如下:
session_start();
$allow_sep = "2";
if (isset($_SESSION["post_sep"]))
{
if (time() - $_SESSION["post_sep"] < $allow_sep)
{
exit("請不要頻繁刷新,休息2秒再刷新吧");
}
else
{
$_SESSION["post_sep"] = time();
}
}
else
{
$_SESSION["post_sep"] = time();
}
?>
方法三,代碼如下:
session_start();
if(!emptyempty($_POST[name])){
$data = $_POST[name];
$tag = $_POST[tag];
if($_SESSION[status]==$tag){
echo $data;
}else{
echo "不允許刷新!";
}
}
$v = mt_rand(1,10000);
?>
<form method="post" name="magic" action="f5.php"><input type="hidden"
name="tag" value="<?=$v?>"><input type=text name="name"><input type="submit" value="submit">
</form>
<?php
echo $v;
$_SESSION[status] = $v;
?>
注意:代碼有了,不過要應用到WordPress還要一些其他操作.
因為上面的代碼是基于 session的驗證,假設你在2秒內刷新了頁面,那么他會執(zhí)行exit() 函數(shù)輸出一條消息,并退出當前腳本,于是就不會加載下面的內容,所以這段代碼最好放在header中,先讓代碼執(zhí)行,再加載其他的東西.
如果把代碼放在了footer里,結果整個頁面都加載了只在最后一行輸出了"請不要頻繁刷新",放在header中,效果比較好,想看效果的話按兩下F5 吧.
當然最好的是采用的是新建一個php文件,然后在header調用.
這樣做的好處有兩個:
一個是修改功能代碼方便,不用每次都打開header文件,也不怕誤改了其他地方的代碼,二是一旦出錯,可以快速修改并檢查,甚至可以直接刪除文件,代碼如下:
include('includes/forbiddenCC.php');
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
這里要注意下,必須調用在所有頁面的最前面.
希望本文所述對大家的PHP程序設計有所幫助。
相關文章
php數(shù)組函數(shù)序列之prev() - 移動數(shù)組內部指針到上一個元素的位置,并返回該元素值
prev() 函數(shù)把指向當前元素的指針移動到上一個元素的位置,并返回該元素值。如果內部指針已經(jīng)超過數(shù)組的第一個元素之前,函數(shù)返回 false2011-10-10PHP連接MSSQL2008/2005數(shù)據(jù)庫(SQLSRV)配置實例
這篇文章主要介紹了PHP連接MSSQL2008/2005數(shù)據(jù)庫(SQLSRV)配置方法,實例講述了完整的連接與配置過程,并提供了具體的擴展文件下載與測試代碼,需要的朋友可以參考下2014-10-10