亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

php防止CC攻擊代碼 php防止網(wǎng)頁頻繁刷新

 更新時間:2015年12月21日 09:33:16   投稿:lijiao  
這篇文章主要介紹了php防止CC攻擊代碼和php防止網(wǎng)頁頻繁刷新,網(wǎng)頁快速惡意刷新,cc攻擊利用代理服務(wù)器生成指向目標(biāo)站點的合法請求,模擬多用戶不停的對受害網(wǎng)站進行訪問,感興趣的小伙伴們可以研究一下

網(wǎng)頁快速惡意刷新,cc攻擊就是攻擊者利用代理服務(wù)器生成指向目標(biāo)站點的合法請求,模擬多用戶不停的對受害網(wǎng)站進行訪問,特別是訪問那些需要大量數(shù)據(jù)操作需要大量CUP時間的頁面,最終導(dǎo)致目標(biāo)網(wǎng)站服務(wù)器資源耗盡,一直到宕機崩潰,如此一來,造成服務(wù)器資源的浪費,CPU長時間處于100%,永遠都有處理不完的連接直至就網(wǎng)絡(luò)擁塞,正常的訪問被中止。我們稱之為CC攻擊。盡管我們可以借助于一些防攻擊的軟件來實現(xiàn),不過效果有時并不明顯。

下面我提供一段PHP的代碼,可以起到一定的防CC攻擊效果。
主要功能:在3秒內(nèi)連續(xù)刷新頁面5次以上將指向本機 http://127.0.0.1 
只需將該代碼放到需要防CC攻擊的頁面即可。
源碼

<?php
$timestampcc = time();
$cc_nowtime = $timestampcc;
if(session_is_registered('cc_lasttime')){
 $cc_lasttime = $_SESSION['cc_lasttime'];
 $cc_times = $_SESSION['cc_times']+1;
 $_SESSION['cc_times'] = $cc_times;
}else{
 $cc_lasttime = $cc_nowtime;
 $cc_times = 1;
 $_SESSION['cc_times'] = $cc_times;
 $_SESSION['cc_lasttime'] = $cc_lasttime;
} 
if(($cc_nowtime-$cc_lasttime)<3){//3秒內(nèi)刷新5次以上可能為cc攻擊
 if($cc_times>=5){
 echo '刷新太快!';
 exit;
 }
}else{
 $cc_times = 0;
 $_SESSION['cc_lasttime'] = $cc_nowtime;
 $_SESSION['cc_times'] = $cc_times;
} 
?>

下面是為大家整理的PHP防CC攻擊的有效方法:

1.session記錄
submit.php為發(fā)送頁面,在這個頁面上設(shè)置一個session變量,并作為隱藏域和表單一起發(fā)送到submitdeal.php頁面,在服務(wù)器端把post上來的隱藏變量和服務(wù)器端記錄的session變量進行對比,比如一樣,則寫入數(shù)據(jù)庫并清除session,這樣用戶刷新頁面,兩個值不相等提示錯誤或跳轉(zhuǎn)。
優(yōu)點:不用用戶輸入驗證碼
缺點:表單容易被復(fù)制
2.驗證碼
原理和第一種一樣,只是session數(shù)據(jù)不作為隱藏域提交,而是讓用戶填寫,大多數(shù)網(wǎng)站都采用文字驗證碼和圖片驗證碼,圖片驗證碼安全性高。

3.IP綁定
提交數(shù)據(jù)后,先從IP表里檢索客戶端IP,如果有,并且沒有過期,那么報錯,否則寫入數(shù)據(jù)庫,然后再取客房端IP,把IP寫入數(shù)據(jù)庫。
4.cookie:客戶提交后處理程序先檢索客戶端有沒有設(shè)置cookie,如果有,則不重復(fù)提交;如果沒有,則寫數(shù)據(jù),再寫個cookie;
例:

用戶無意義的頻繁跳轉(zhuǎn)、請求都會給服務(wù)器加重很多負(fù)擔(dān) 其實 用cookie就可以防止這一點。

<?php 
error_reporting(0); 
//if($_COOKIE["ck"])die("刷新過快!"); 
if($_COOKIE["ck"])header("Location:http://www.baidu.com");//這里如果用戶刷新過快,給予終止php腳本或者直接302跳轉(zhuǎn) 
setcookie("ck","1",time()+3);//設(shè)定cookie存活時間3s 
echo "hello!"; 
?>

方式一:

<?php  
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(); 
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> 
<? 
echo $v; 
$_SESSION[status] = $v; 
?> 

方式三:

<? 
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> 
<? 
echo $v; 
$_SESSION[status] = $v; 
?> 

以上就是php防止CC攻擊的多種方式,希望能幫助大家防止網(wǎng)頁快速惡意刷新。

相關(guān)文章

  • php中strtotime函數(shù)用法詳解

    php中strtotime函數(shù)用法詳解

    這篇文章主要介紹了php中strtotime函數(shù)的用法,以實例形式詳細分析了strtotime函數(shù)的參數(shù)含義與相應(yīng)的用法,適用于時間格式變換的情況,需要的朋友可以參考下
    2014-11-11
  • PHP使用Reli分析性能,生成PHP性能火焰圖

    PHP使用Reli分析性能,生成PHP性能火焰圖

    Reli 是一個用PHP編寫的采樣分析器(或VM狀態(tài)檢查器),它可以從進程外部讀取有關(guān)運行PHP腳本的信息,它是一個獨立的CLI工具,因此目標(biāo)程序不需要任何修改,檢測和可視化PHP腳本中的瓶頸,它不僅提供函數(shù)級的分析,而且還提供行級或操作碼級的解析
    2024-01-01
  • php的一個登錄的類 [推薦]

    php的一個登錄的類 [推薦]

    php的一個登錄的類 [推薦]...
    2007-03-03
  • Yii 使用intervention/image拓展實現(xiàn)圖像處理功能

    Yii 使用intervention/image拓展實現(xiàn)圖像處理功能

    這篇文章主要介紹了Yii 使用intervention/image拓展實現(xiàn)圖像處理功能,需要的朋友可以參考下
    2019-06-06
  • 關(guān)于PHP的curl開啟問題探討

    關(guān)于PHP的curl開啟問題探討

    新浪提供的PHP SDK里需要用到curl_init()函數(shù),在調(diào)試的時候報找不到curl_init()的方法,下面為大家介紹下開啟curl的步驟
    2014-04-04
  • PHP @ at 記號的作用示例介紹

    PHP @ at 記號的作用示例介紹

    @符號一直不知道是什么意思,其實它是錯誤控制符,即即使出現(xiàn)錯誤,也無視出現(xiàn)的錯誤信息,繼續(xù)執(zhí)行下邊的代碼
    2014-10-10
  • PHP中的use關(guān)鍵字及文件的加載詳解

    PHP中的use關(guān)鍵字及文件的加載詳解

    最近有個朋友問我,php中的use關(guān)鍵字是不是會進行文件的自動引入?其實use關(guān)鍵字與文件加載沒有一點關(guān)系,use關(guān)鍵字的作用就是聲明要使用的類所處那個命名空間之下。下面通過這篇文章跟著小編一起學(xué)習(xí)下PHP中的use關(guān)鍵字及文件的加載。
    2016-11-11
  • php實現(xiàn)轉(zhuǎn)換ubb代碼的方法

    php實現(xiàn)轉(zhuǎn)換ubb代碼的方法

    這篇文章主要介紹了php實現(xiàn)轉(zhuǎn)換ubb代碼的方法,涉及php正則替換的使用技巧,需要的朋友可以參考下
    2015-06-06
  • PHP編程實現(xiàn)微信企業(yè)向用戶付款的方法示例

    PHP編程實現(xiàn)微信企業(yè)向用戶付款的方法示例

    這篇文章主要介紹了PHP編程實現(xiàn)微信企業(yè)向用戶付款的方法,涉及php針對微信接口調(diào)用、配置及交互操作相關(guān)技巧,需要的朋友可以參考下
    2017-07-07
  • 淺析PHP程序設(shè)計中的MVC編程思想

    淺析PHP程序設(shè)計中的MVC編程思想

    這篇文章主要介紹了PHP程序設(shè)計中的MVC編程思想,對于深入理解MVC程序設(shè)計思想有一定的幫助,需要的朋友可以參考下
    2014-07-07

最新評論