php防攻击代码升级版_PHP教程
不过最近几天突然糟糕了起来,有90%的攻击已经没法拦截,请看下图一天的统计:
IP攻击及开始时间 | 攻击次数 | 地点 | 备注 |
125.165.1.42--2010-11-19 02:02:19--/ | 10 | 印度尼西亚 | |
125.165.26.186--2010-11-19 16:56:45--/ | 1846 | 印度尼西亚 | |
151.51.238.254--2010-11-19 09:32:40--/ | 4581 | 意大利 | |
151.76.40.182--2010-11-19 11:58:37--/ | 4763 | 意大利 罗马 | |
186.28.125.37--2010-11-19 11:19:22--/ | 170 | 哥伦比亚 | |
186.28.131.122--2010-11-19 11:28:43--/ | 22 | 哥伦比亚 | |
186.28.25.130--2010-11-19 11:30:20--/ | 1530 | 哥伦比亚 | |
188.3.1.108--2010-11-19 02:48:28--/ | 1699 | 土耳其 | |
188.3.1.18--2010-11-19 06:46:01--/ | 1358 | 土耳其 | |
188.3.34.226--2010-11-19 17:07:02--/ | 1672 | 土耳其 | |
190.24.50.228--2010-11-19 12:26:38--/ | 2038 | 哥伦比亚 | |
190.24.83.82--2010-11-19 14:20:10--/ | 9169 | 哥伦比亚 | |
190.25.30.213--2010-11-19 14:00:44--/ | 680 | 哥伦比亚 | |
190.26.29.130--2010-11-19 13:33:11--/ | 510 | 哥伦比亚 | |
190.27.115.101--2010-11-19 13:53:48--/ | 340 | 哥伦比亚 | |
190.27.22.222--2010-11-19 12:16:02--/ | 340 | 哥伦比亚 | |
201.244.113.165--2010-11-19 11:25:55--/ | 170 | 哥伦比亚 | |
201.244.113.47--2010-11-19 11:24:56--/ | 147 | 哥伦比亚 | |
201.244.115.156--2010-11-19 10:13:56--/ | 2031 | 哥伦比亚 | |
201.244.119.228--2010-11-19 13:50:05--/ | 170 | 哥伦比亚 | |
201.245.218.155--2010-11-19 13:30:30--/ | 21 | 哥伦比亚 | |
212.156.185.122--2010-11-19 08:40:36--/ | 16158 | 土耳其 | |
78.160.106.60--2010-11-19 03:31:12--/ | 340 | 土耳其 | |
78.162.67.77--2010-11-19 04:26:24--/ | 3595 | 土耳其 | 程序已抓 |
78.175.64.173--2010-11-19 02:00:08--/ | 2877 | 土耳其 | |
78.176.178.76--2010-11-19 06:12:05--/ | 2370 | 土耳其 | |
78.177.2.86--2010-11-19 13:24:29--/ | 196 | 土耳其 | |
78.181.76.51--2010-11-19 16:04:29--/ | 600 | 土耳其 | |
78.184.145.63--2010-11-19 14:30:12--/ | 2542 | 土耳其 | |
78.185.168.24--2010-11-19 09:02:52--/ | 3877 | 土耳其 | |
78.190.79.225--2010-11-19 13:25:22--/ | 3300 | 土耳其 | |
78.190.84.230--2010-11-19 06:51:33--/ | 2719 | 土耳其 | |
78.191.149.47--2010-11-19 08:34:34--/ | 8783 | 土耳其 | |
78.191.233.108--2010-11-19 05:10:48--/ | 340 | 土耳其 | |
78.191.94.126--2010-11-19 04:34:26--/ | 3091 | 土耳其 | |
85.104.231.74--2010-11-19 08:03:53--/ | 3500 | 土耳其 | |
85.104.49.60--2010-11-19 04:47:12--/ | 1037 | 土耳其 | |
85.106.123.116--2010-11-19 13:35:45--/ | 68 | 土耳其 | |
88.224.255.96--2010-11-19 07:18:59--/ | 3903 | 土耳其 | |
88.228.138.65--2010-11-19 02:12:31--/ | 396 | 土耳其 | |
88.228.66.5--2010-11-19 10:44:26--/ | 2797 | 土耳其 | |
88.229.12.40--2010-11-19 06:57:46--/ | 6792 | 土耳其 | |
88.234.193.11--2010-11-19 08:25:42--/ | 5895 | 土耳其 | |
88.236.78.79--2010-11-19 15:01:54--/ | 170 | 土耳其 | |
88.238.26.12--2010-11-19 05:21:46--/ | 473 | 土耳其 | |
88.238.26.154--2010-11-19 05:31:58--/ | 1683 | 土耳其 | |
88.242.124.128--2010-11-19 06:53:56--/ | 8401 | 土耳其 | |
88.242.65.61--2010-11-19 08:38:41--/ | 1204 | 土耳其 | 程序已抓 |
94.122.20.157--2010-11-19 09:53:39--/ | 1917 | 土耳其 美国 | 程序已抓 |
94.54.37.54--2010-11-19 02:44:07--/ | 1096 | 土耳其 美国 | 程序已抓 |
95.14.1.97--2010-11-19 08:30:10--/ | 167 | 土耳其 美国 | |
95.15.248.177--2010-11-19 11:14:54--/ | 1454 | 土耳其 美国 | 程序已抓 |
共125008次,快的15秒172次,只抓9266次。 |
这个表够糟糕的了,我们网站一天被攻击了12万次之多,如果任由其乱来,会给网站的负担带来的网速影响是显而易见的,该攻击的特点是每当发起攻击的时候都会由3-5个不同的IP同时以每秒3-5次的速度攻击过来,合计起来每秒钟就达9-25次,每过1-6小时换一次IP,而且IP和以前的记录是不重复的。这样,一来是网站内存会突然过大,亮灯;二来是给网络带来很大的不稳定性。个别IP是封了一直存在的,我试过全部解封了,一解封就有好几个IP同时进行攻击,甚至会让网站严重过载了几分钟。
现在,开始本期的话题,为什么会挡不住新的攻击了呢?经过研究,我发现那90%的IP采用了新的攻击方案:已经智能的能攻击2分钟停5分钟的轮流攻击,由于我上次的程序参数设置为600秒/期的保守方案,所以,我把参数改为了120秒120次的新方案,错杀率0.5%以内,经过log的对比,我可以分析出120秒120次错杀是未曾试过的,120秒多1次也只是有一个运费页面由于网络问题有个客户刷新多了1回,这是我们的交易后台的原因不够智能化居多。
最后,感谢大家的留言,你们的留言我都会思考的。不过,我这个程序只是个参考,因地制宜,也不是最好的,只能说是人性化的罢了。现在我把程序再发一遍,只改了时间次数参数,新的参数已经能100%抓住那些黑客IP,我试验了两天,抓了62个新IP,还是土耳其的居多。
网站防IP攻击代码(Anti-IP attack code website) ver2.0:
/*
*网站防IP攻击代码(Anti-IP attack code website)2010-11-20,Ver2.0
*Mydalle.com Anti-refresh mechanism
*design by www.mydalle.com
*/
//查询禁止IP
$ip =$_SERVER['REMOTE_ADDR'];
$fileht=".htaccess2";
if(!file_exists($fileht))file_put_contents($fileht,"");
$filehtarr=@file($fileht);
if(in_array($ip."\r\n",$filehtarr))die("Warning:"."
"."Your IP address are forbided by Mydalle.com Anti-refresh mechanism, IF you have any question Pls emill to shop@mydalle.com!
(Mydalle.com Anti-refresh mechanism is to enable users to have a good shipping services, but there maybe some inevitable network problems in your IP address, so that you can mail to us to solve.)");
//加入禁止IP
$time=time();
$fileforbid="log/forbidchk.dat";
if(file_exists($fileforbid))
{ if($time-filemtime($fileforbid)>30)unlink($fileforbid);
else{
$fileforbidarr=@file($fileforbid);
if($ip==substr($fileforbidarr[0],0,strlen($ip)))
{
if($time-substr($fileforbidarr[1],0,strlen($time))>120)unlink($fileforbid);
elseif($fileforbidarr[2]>120){file_put_contents($fileht,$ip."\r\n",FILE_APPEND);unlink($fileforbid);}
else{$fileforbidarr[2]++;file_put_contents($fileforbid,$fileforbidarr);}
}
}
}
//防刷新
$str="";
$file="log/ipdate.dat";
if(!file_exists("log")&&!is_dir("log"))mkdir("log",0777);
if(!file_exists($file))file_put_contents($file,"");
$allowTime = 60;//防刷新时间
$allowNum=5;//防刷新次数
$uri=$_SERVER['REQUEST_URI'];
$checkip=md5($ip);
$checkuri=md5($uri);
$yesno=true;
$ipdate=@file($file);
foreach($ipdate as $k=>$v)
{ $iptem=substr($v,0,32);
$uritem=substr($v,32,32);
$timetem=substr($v,64,10);
$numtem=substr($v,74);
if($time-$timetemif($iptem!=$checkip)$str.=$v;
else{
$yesno=false;
if($uritem!=$checkuri)$str.=$iptem.$checkuri.$time."1\r\n";
elseif($numtemelse
{
if(!file_exists($fileforbid)){$addforbidarr=array($ip."\r\n",time()."\r\n",1);file_put_contents($fileforbid,$addforbidarr);}
file_put_contents("log/forbided_ip.log",$ip."--".date("Y-m-d H:i:s",time())."--".$uri."\r\n",FILE_APPEND);
$timepass=$timetem+$allowTime-$time;
die("Warning:"."
"."Pls don't refresh too frequently, and wait for ".$timepass." seconds to continue, IF not your IP address will be forbided automatic by Mydalle.com Anti-refresh mechanism!
(Mydalle.com Anti-refresh mechanism is to enable users to have a good shipping services, but there maybe some inevitable network problems in your IP address, so that you can mail to us to solve.)");
}
}
}
}
if($yesno) $str.=$checkip.$checkuri.$time."1\r\n";
file_put_contents($file,$str);
?>

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

PHP 8.4 帶來了多項新功能、安全性改進和效能改進,同時棄用和刪除了大量功能。 本指南介紹如何在 Ubuntu、Debian 或其衍生版本上安裝 PHP 8.4 或升級到 PHP 8.4

Visual Studio Code,也稱為 VS Code,是一個免費的原始碼編輯器 - 或整合開發環境 (IDE) - 可用於所有主要作業系統。 VS Code 擁有大量針對多種程式語言的擴展,可以輕鬆編寫

本教程演示瞭如何使用PHP有效地處理XML文檔。 XML(可擴展的標記語言)是一種用於人類可讀性和機器解析的多功能文本標記語言。它通常用於數據存儲

字符串是由字符組成的序列,包括字母、數字和符號。本教程將學習如何使用不同的方法在PHP中計算給定字符串中元音的數量。英語中的元音是a、e、i、o、u,它們可以是大寫或小寫。 什麼是元音? 元音是代表特定語音的字母字符。英語中共有五個元音,包括大寫和小寫: a, e, i, o, u 示例 1 輸入:字符串 = "Tutorialspoint" 輸出:6 解釋 字符串 "Tutorialspoint" 中的元音是 u、o、i、a、o、i。總共有 6 個元

JWT是一種基於JSON的開放標準,用於在各方之間安全地傳輸信息,主要用於身份驗證和信息交換。 1.JWT由Header、Payload和Signature三部分組成。 2.JWT的工作原理包括生成JWT、驗證JWT和解析Payload三個步驟。 3.在PHP中使用JWT進行身份驗證時,可以生成和驗證JWT,並在高級用法中包含用戶角色和權限信息。 4.常見錯誤包括簽名驗證失敗、令牌過期和Payload過大,調試技巧包括使用調試工具和日誌記錄。 5.性能優化和最佳實踐包括使用合適的簽名算法、合理設置有效期、

靜態綁定(static::)在PHP中實現晚期靜態綁定(LSB),允許在靜態上下文中引用調用類而非定義類。 1)解析過程在運行時進行,2)在繼承關係中向上查找調用類,3)可能帶來性能開銷。

PHP的魔法方法有哪些? PHP的魔法方法包括:1.\_\_construct,用於初始化對象;2.\_\_destruct,用於清理資源;3.\_\_call,處理不存在的方法調用;4.\_\_get,實現動態屬性訪問;5.\_\_set,實現動態屬性設置。這些方法在特定情況下自動調用,提升代碼的靈活性和效率。
