与StackOverflow上的许多其他线程一致,我使用以下代码来检测用户的IP地址:
function get_ip_address(){
foreach (array('HTTP_CLIENT_IP', 'HTTP_X_FORWARDED_FOR', 'HTTP_X_FORWARDED', 'HTTP_X_CLUSTER_CLIENT_IP', 'HTTP_FORWARDED_FOR', 'HTTP_FORWARDED', 'REMOTE_ADDR') as $key){
if (array_key_exists($key, $_SERVER) === true){
foreach (explode(',', $_SERVER[$key]) as $ip){
$ip = trim($ip); // just to be safe
if (filter_var($ip, FILTER_VALIDATE_IP, FILTER_FLAG_NO_PRIV_RANGE | FILTER_FLAG_NO_RES_RANGE) !== false){
return $ip;
}
}
}
}
}
该代码通常可以正常工作。但是,最近我遇到了上述代码无法正确检测用户IP地址的情况。
例如,当用户的IP地址为184.105.xxx.xxx时,我得到的IP地址为209.141.xxx.xxx。 209.141.xxx.xxx是数据中心的IP地址,因此我认为他们使用的是某种VPN,而我无法获得他们的真实IP。显然,他们使用的是AdGuard,它不是VPN,但可以做伪VPN。但是,这就是事情。即使AdGuard已打开:
1)网站whatismyip.com为用户显示209.141.xxx.xxx(就像我的网站使用上述PHP代码一样)
2)网站whatismyipaddress.com向用户显示正确的IP地址184.105.xxx.xxx
因此,即使用户打开了AdGuard之类的东西,而我的代码只是做错了,显然还有一种方法可以获取正确的IP地址?