Оновлення : CloudFlare випустив модуль mod_cloudflare
для apache, модуль реєструватиме і відображатиме фактичні IP-адреси відвідувачів, а не ті, до яких отримує доступ Cloudflare! https://www.cloudflare.com/resources-downloads#mod_cloudflare (відповідь: olimortimer )
Якщо у вас немає доступу до середовища роботи apache, ви можете скористатися наведеним нижче сценарієм, це дозволить вам перевірити, чи було з'єднання через cloudflare, і отримати ip користувачів.
Я переписую свою відповідь, яку використовував для іншого запитання " CloudFlare DNS / прямий ідентифікатор IP "
IP-адреси Cloudflare зберігаються загальнодоступно, тому ви можете перейти до них, щоб переглянути їх тут, а потім перевірити, чи не ip від Cloudflare (це дозволить нам отримати справжній ip із заголовка http HTTP_CF_CONNECTING_IP
).
Якщо ви використовуєте це для вимкнення всіх з’єднань, не пов’язаних із cf, або навпаки, я рекомендую вам мати один файл сценарію php, який викликається перед кожним іншим сценарієм, таким як common.php або pagestart.php тощо.
function ip_in_range($ip, $range) {
if (strpos($range, '/') == false)
$range .= '/32';
list($range, $netmask) = explode('/', $range, 2);
$range_decimal = ip2long($range);
$ip_decimal = ip2long($ip);
$wildcard_decimal = pow(2, (32 - $netmask)) - 1;
$netmask_decimal = ~ $wildcard_decimal;
return (($ip_decimal & $netmask_decimal) == ($range_decimal & $netmask_decimal));
}
function _cloudflare_CheckIP($ip) {
$cf_ips = array(
'199.27.128.0/21',
'173.245.48.0/20',
'103.21.244.0/22',
'103.22.200.0/22',
'103.31.4.0/22',
'141.101.64.0/18',
'108.162.192.0/18',
'190.93.240.0/20',
'188.114.96.0/20',
'197.234.240.0/22',
'198.41.128.0/17',
'162.158.0.0/15',
'104.16.0.0/12',
);
$is_cf_ip = false;
foreach ($cf_ips as $cf_ip) {
if (ip_in_range($ip, $cf_ip)) {
$is_cf_ip = true;
break;
}
} return $is_cf_ip;
}
function _cloudflare_Requests_Check() {
$flag = true;
if(!isset($_SERVER['HTTP_CF_CONNECTING_IP'])) $flag = false;
if(!isset($_SERVER['HTTP_CF_IPCOUNTRY'])) $flag = false;
if(!isset($_SERVER['HTTP_CF_RAY'])) $flag = false;
if(!isset($_SERVER['HTTP_CF_VISITOR'])) $flag = false;
return $flag;
}
function isCloudflare() {
$ipCheck = _cloudflare_CheckIP($_SERVER['REMOTE_ADDR']);
$requestCheck = _cloudflare_Requests_Check();
return ($ipCheck && $requestCheck);
}
function getRequestIP() {
$check = isCloudflare();
if($check) {
return $_SERVER['HTTP_CF_CONNECTING_IP'];
} else {
return $_SERVER['REMOTE_ADDR'];
}
}
Користуватися сценарієм досить просто:
$ip = getRequestIP();
$cf = isCloudflare();
if($cf) echo "Connection is through cloudflare: <br>";
else echo "Connection is not through cloudflare: <br>";
echo "Your actual ip address is: ". $ip;
echo "The server remote address header is: ". $_SERVER['REMOTE_ADDR'];
Цей скрипт покаже вам справжню ip-адресу, і якщо запит є CF чи ні!