我目前有一个PHP函数,应该确定我网站上每个访问者的IP地址,但由于某种原因它不断返回此IP地址:10.1.1.27即使我使用vpn更改我的IP地址(对于另一个国家,例如美国,德国,英国),它仍然返回该地址。我希望有人可以向我解释这个问题,如果可能的话,请告诉我这是否与我的代码有关?
功能:
function getIP(){
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);
if (filter_var($ip, FILTER_VALIDATE_IP, FILTER_FLAG_NO_PRIV_RANGE | FILTER_FLAG_NO_RES_RANGE) !== false){
return $ip;
}else{
echo $ip;
throw new Exception("IP address is not valid");
}
}
}
}
}
答案 0 :(得分:0)
我的猜测是你有防火墙或其他物理设备NAT访问者的IP地址。
您是否已执行反向查找以查看网络上的IP地址?
答案 1 :(得分:0)
这可能会帮助你......
<?php
if (getenv('HTTP_X_FORWARDED_FOR')) {
$pipaddress = getenv('HTTP_X_FORWARDED_FOR');
$ipaddress = getenv('REMOTE_ADDR');
echo "Your Proxy IP address is : ".$pipaddress. "(via $ipaddress)" ;
} else {
$ipaddress = getenv('REMOTE_ADDR');
echo "Your IP address is : $ipaddress";
}
?>
答案 2 :(得分:0)
我有同样的问题。事实证明,我得到的是代理IP地址而不是我自己的IP。所以我跑了:
var_dump($_SERVER)
//you could also use print_r($_SERVER);
然后找了这样的东西:
["HTTP_X_REAL_IP"]
然后把它捕获到这样的var中:
$ip = getenv('HTTP_X_REAL_IP')