Файл: files/class_ipinit.php
Строк: 48
<?
$rootpath = '../';
class ipinit {
public $ip; // IP адрес в LONG формате
public $flood_chk = 1; // Включение - выключение функции IP антифлуда
public $flood_interval = '120'; // Интервал времени в секундах
public $flood_limit = '20'; // Число разрешенных запросов за интервал
public $flood_file = 'http_antiflood.dat'; // Рабочий файл функции
private $requests; // Число запросов с IP адреса за период времени
function __construct() {
$this->ip = ip2long($this->getip());
// Проверка адреса IP на HTTP флуд
if ($this->flood_chk) {
$this->requests = $this->reqcount();
if ($this->requests > $this->flood_limit)
die('DDoS DEFENDER!!!!!');
}
}
function getIPfromXForwarded() {
$ipString = @ getenv("HTTP_X_FORWARDED_FOR");
$addr = explode(",", $ipString);
return $addr[sizeof($addr) - 1];
}
// Получаем реальный адрес IP
private function getip() {
if (isset ($_SERVER['HTTP_X_FORWARDED_FOR'])) {
$ip = explode(",", $_SERVER['HTTP_X_FORWARDED_FOR']);
return $ip[sizeof($ip) - 1];
}
elseif ($_SERVER['REMOTE_ADDR']) {
return $_SERVER['REMOTE_ADDR'];
}
else {
die('Unknown IP');
}
}
// Счетчик числа обращений с данного IP
private function reqcount() {
global $rootpath;
$tmp = array();
$requests = 1;
if (!file_exists('cache/' . $this->flood_file))
$in = fopen('cache/' . $this->flood_file, "w+");
else
$in = fopen('cache/' . $this->flood_file, "r+");
flock($in, LOCK_EX) or die("Cannot flock ANTIFLOOD file.");
$now = time();
while ($block = fread($in, 8)) {
$arr = unpack("Lip/Ltime", $block);
if (($now - $arr['time']) > $this->flood_interval) {
continue;
}
if ($arr['ip'] == $this->ip) {
$requests++;
}
$tmp[] = $arr;
}
fseek($in, 0);
ftruncate($in, 0);
for ($i = 0; $i < count($tmp); $i++) {
fwrite($in, pack('LL', $tmp[$i]['ip'], $tmp[$i]['time']));
}
fwrite($in, pack('LL', $this->ip, $now));
fclose($in);
return $requests;
}
}
?>