Created
July 9, 2021 09:29
-
-
Save A973C/61e38a3bfe78000bc6946f245826c7ee to your computer and use it in GitHub Desktop.
Get client IP address
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// Source: https://stackoverflow.com/a/28217316/15939309 | |
function get_ip_address() { | |
// Check for shared Internet/ISP IP | |
if (!empty($_SERVER['HTTP_CLIENT_IP']) && validate_ip($_SERVER['HTTP_CLIENT_IP'])) { | |
return $_SERVER['HTTP_CLIENT_IP']; | |
} | |
// Check for IP addresses passing through proxies | |
if (!empty($_SERVER['HTTP_X_FORWARDED_FOR'])) { | |
// Check if multiple IP addresses exist in var | |
if (strpos($_SERVER['HTTP_X_FORWARDED_FOR'], ',') !== false) { | |
$iplist = explode(',', $_SERVER['HTTP_X_FORWARDED_FOR']); | |
foreach ($iplist as $ip) { | |
if (validate_ip($ip)) | |
return $ip; | |
} | |
} | |
else { | |
if (validate_ip($_SERVER['HTTP_X_FORWARDED_FOR'])) | |
return $_SERVER['HTTP_X_FORWARDED_FOR']; | |
} | |
} | |
if (!empty($_SERVER['HTTP_X_FORWARDED']) && validate_ip($_SERVER['HTTP_X_FORWARDED'])) | |
return $_SERVER['HTTP_X_FORWARDED']; | |
if (!empty($_SERVER['HTTP_X_CLUSTER_CLIENT_IP']) && validate_ip($_SERVER['HTTP_X_CLUSTER_CLIENT_IP'])) | |
return $_SERVER['HTTP_X_CLUSTER_CLIENT_IP']; | |
if (!empty($_SERVER['HTTP_FORWARDED_FOR']) && validate_ip($_SERVER['HTTP_FORWARDED_FOR'])) | |
return $_SERVER['HTTP_FORWARDED_FOR']; | |
if (!empty($_SERVER['HTTP_FORWARDED']) && validate_ip($_SERVER['HTTP_FORWARDED'])) | |
return $_SERVER['HTTP_FORWARDED']; | |
// Return unreliable IP address since all else failed | |
return $_SERVER['REMOTE_ADDR']; | |
} | |
/** | |
* Ensures an IP address is both a valid IP address and does not fall within | |
* a private network range. | |
*/ | |
function validate_ip($ip) { | |
if (strtolower($ip) === 'unknown') | |
return false; | |
// Generate IPv4 network address | |
$ip = ip2long($ip); | |
// If the IP address is set and not equivalent to 255.255.255.255 | |
if ($ip !== false && $ip !== -1) { | |
// Make sure to get unsigned long representation of IP address | |
// due to discrepancies between 32 and 64 bit OSes and | |
// signed numbers (ints default to signed in PHP) | |
$ip = sprintf('%u', $ip); | |
// Do private network range checking | |
if ($ip >= 0 && $ip <= 50331647) | |
return false; | |
if ($ip >= 167772160 && $ip <= 184549375) | |
return false; | |
if ($ip >= 2130706432 && $ip <= 2147483647) | |
return false; | |
if ($ip >= 2851995648 && $ip <= 2852061183) | |
return false; | |
if ($ip >= 2886729728 && $ip <= 2887778303) | |
return false; | |
if ($ip >= 3221225984 && $ip <= 3221226239) | |
return false; | |
if ($ip >= 3232235520 && $ip <= 3232301055) | |
return false; | |
if ($ip >= 4294967040) | |
return false; | |
} | |
return true; | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment