Блокировать определенный IP-блок с моего сайта в PHP
Я хотел бы, например, заблокировать каждый IP из базы 89.95 (89.95..).
У меня нет файлов .htaccess
на моем сервере, поэтому мне придется делать это с помощью PHP.
if ($_SERVER['REMOTE_ADDR'] == "89.95.25.37") die();
Блокирует определенный IP-адрес. Как заблокировать все блоки IP?
Большое спасибо.
Ответы
Ответ 1
Попробуйте strpos()
if(strpos($_SERVER['REMOTE_ADDR'], "89.95") === 0)
{
die();
}
Если вы заметили, оператор ===
гарантирует, что 89.95
находится на начальном IP-адреса. Это означает, что вы можете обезопасить столько IP-адресов, сколько захотите, и он будет блокировать независимо от того, какие числа приходят после него.
Например, все они будут заблокированы:
89.95 → 89.95.12.34
, 89.95.1234.1
, 89.95.1.1
89.95.6 → 89.95.65.34
, 89.95.61.1
, 89.95.6987
(некоторые из них не являются действительными IP-адресами, хотя)
Ответ 2
Используйте ip2long()
для преобразования десятичного десятичного разряда в реальный IP-адрес. Тогда вы можете легко делать диапазоны.
Просто выполните ip2long()
в верхнем и нижнем диапазонах, чтобы получить значение, а затем используйте их как константы в вашем коде.
Если вы знакомы с маскировкой подсети, вы можете сделать это следующим образом:
// Deny 10.12.*.*
$network = ip2long("10.12.0.0");
$mask = ip2long("255.255.0.0");
$ip = ip2long($_SERVER['REMOTE_ADDR']);
if (($network & $mask) == ($ip & $mask)) {
die("Unauthorized");
}
Или, если вы знакомы с этим форматом 10.12.0.0/16
:
// Deny 10.12.*.*
$network = ip2long("10.12.0.0");
$prefix = 16;
$ip = ip2long($_SERVER['REMOTE_ADDR']);
if ($network >> (32 - $prefix)) == ($ip >> (32 - $prefix)) {
die("Unauthorized");
}
Вы можете включить их в функции и иметь очень управляемый код, что упрощает добавление IP-адресов и настройку диапазонов.
Ответ 3
Преобразуйте пунктирный квадрат в целое число:
$ip = sprintf('%u', ip2long($_SERVER['REMOTE_ADDR']));
// only allow 10.0.0.0 – 10.255.255.255
if (!($ip >= 167772160 && $ip <= 184549375)) {
die('Forbidden.');
}
Ответ 4
Сделайте подстроку:)
Например, для блокировки 89.95.25. * Вы создаете подстроку IP, отсекая последние два числа и сравнивая его с "89.95.25".
Ответ 5
$user_ip = $_SERVER['REMOTE_ADDR']; // get user ip
$denyIPs = array("111.111.111", "222.222.222", "333.333.333");
if (in_array ($user_ip, $denyIPs)) {
// blocked ip
}
else {
// not blocked
}
Ответ 6
Это всегда хорошо срабатывало для меня:
Это проверяет правильные серверные переменные и сравнивает их со списком известных IP-адресов.. и да, PHP действительно понимает подстановочные знаки, поэтому используйте * внутри IP-адреса, помогая блокировать диапазоны IP-адресов.
// The blacklisted ips.
$denied_ips = array(
'1.2.3.4',
'2.3.*',
);
// The function to get the visitor IP.
function getUserIP(){
//check ip from share internet
if (!empty($_SERVER['HTTP_CLIENT_IP'])){
$ip=$_SERVER['HTTP_CLIENT_IP'];
}
//to check ip is pass from proxy
elseif (!empty($_SERVER['HTTP_X_FORWARDED_FOR'])){
$ip=$_SERVER['HTTP_X_FORWARDED_FOR'];
} else {
$ip=$_SERVER['REMOTE_ADDR'];
}
return $ip;
}
//The user
$visitorIp = getUserIP();
// Now let search if this IP is blackliated
$status = array_search($visitorIp, $denied_ips);
// Let check if $status has a true OR false value.
if($status !== false){
echo '<div class="error">Your IP has been banned! Stop spamming us!</div>';
// header("Location: http://zombo.com");
// exit;
}
Там также отличная статья в скоропортящейся прессе:
http://perishablepress.com/how-to-block-ip-addresses-with-php/
Ответ 7
используя код восстановления, используйте это для поиска по шаблону
// Now let search if this IP is blackliated
$status = false;
foreach($denied_ips as $val)
{
if (strpos($val,'*') !== false)
{
if(strpos($visitorIp, array_shift(explode("*", $val))) === 0)
{
$status = true;
break;
}
}
else
{
if(strcmp($visitorIp, $val) === 0)
{
$status = true;
break;
}
}
}
Ответ 8
$deny = array("111.111.111", "222.222.222", "333.333.333");
if (in_array($_SERVER['REMOTE_ADDR'], $deny)) {
header("location:http://www.google.com/");
exit();
}