PHP 禁止同一 IP 频繁访问

最近碰到一些不好的事,当时网站设计的结构并不好,这几天碰到有人攻击服务器,导致数据库增长了很多无用数据。在这里也算做个记录吧。

php代码:

<?php
//查询禁止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:" . "<br>" . "Your IP address are forbided by some reason, IF you have any question Pls emill to 2376688759@qq.com!");
//加入禁止IP
$time = time();
$fileforbid = "log/forbidchk.dat";
if (file_exists($fileforbid)) {
    if ($time - filemtime($fileforbid) > 60) unlink($fileforbid);
    else {
        $fileforbidarr = @file($fileforbid);
        if ($ip == substr($fileforbidarr[0], 0, strlen($ip))) {
            if ($time - substr($fileforbidarr[1], 0, strlen($time)) > 600) unlink($fileforbid);
            elseif ($fileforbidarr[2] > 600) {
                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 = 600; //防刷新时间
$allowNum = 5; //防刷新次数
//$uri = $_SERVER['REQUEST_URI'];
$uri = $_SERVER['PHP_SELF'];
$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 - $timetem < $allowTime) {
        if ($iptem != $checkip) $str.= $v;
        else {
            $yesno = false;
            if ($uritem != $checkuri) $str.= $iptem . $checkuri . $time . "1\r\n";
            elseif ($numtem < $allowNum) $str.= $iptem . $uritem . $timetem . ($numtem + 1) . "\r\n";
            else {
                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:" . "<br>" . "Sorry,you are forbided by refreshing frequently too much, Pls wait for " . $timepass . " seconds to continue!");
            }
        }
    }
}
if ($yesno) $str.= $checkip . $checkuri . $time . "1\r\n";
file_put_contents($file, $str);
?>

保存做一个单独的文件,

然后在想防止多次刷新的地方 include 就可以了。

已有 51 条评论

  1. Max

    via真的好

  2. baoyy

    喜欢之前的图标

  3. 1

    测试

  4. 厉害了

  5. ftyswqq

    希望新版的浏览器能弄出来个和以前菜单一样的样式啊,不习惯啊,因为这个一直还在用旧版的( ˙-˙ )

  6. 健身

  7. 浏览器的夜间模式需要改善现在是调低亮度,感觉很鸡肋,建议浏览器反转颜色,跟替换颜色,模仿下腾讯qq的夜间模式色彩。背景深色,字体跟背景颜色对比不大的颜色。

  8. yy

    建议via推出AMOLED模式

添加新评论