我知道这个问题被问过很多次,但我没有得到正确的答案。在这里,我使用以下代码从我的托管网站获取最终用户系统 IP 地址。
function ipCheck() {
if (getenv('HTTP_CLIENT_IP')) {
$ip = getenv('HTTP_CLIENT_IP');
}
elseif (getenv('HTTP_X_FORWARDED_FOR')) {
$ip = getenv('HTTP_X_FORWARDED_FOR');
}
elseif (getenv('HTTP_X_FORWARDED')) {
$ip = getenv('HTTP_X_FORWARDED');
}
elseif (getenv('HTTP_FORWARDED_FOR')) {
$ip = getenv('HTTP_FORWARDED_FOR');
}
elseif (getenv('HTTP_FORWARDED')) {
$ip = getenv('HTTP_FORWARDED');
}
else {
$ip = $_SERVER['REMOTE_ADDR'];
}
return $ip;
}
echo ipCheck();
在我的本地网络中,此代码工作正常。它正确地为我的本地 IP 192.168.xxx.xxx。但是当我在我的网站上运行此代码时,它提供了其他一些 IP 地址。
它工作正常。它将为您提供的IP地址将是您的外部IP地址(转到Google并搜索"我的IP地址是什么",它应该显示您的外部IP是什么,以便您可以根据需要验证您的代码是否正确)。
在本地网络之外托管的服务器上使用时,此地址不会显示您的本地 IP 地址 192.168.x.x,因为请求中未提供该信息。该 IP 地址仅在您的本地网络上有效。
由于IPv4网络中通常的网络地址转换,因此您无法执行此操作。这意味着 NAT 后面的所有 IP 地址都将显示为单个 IP 地址(这将是网关地址),因此,您只能获取网关地址。
除此之外,还有代理服务器,可以隐藏或更改真实的客户端(即他的网关)地址。所以在通常情况下,你的问题有否定的答案,即这是不可能的。
请记住,HTTP_X_FORWARDED_FOR
是一个非强制性的HTTP请求标头,因此可以发送或不发送。它可以是任何东西(使用Firefox下的LiveHTTPHeader之类的东西,我可以在此标头中发送"Hello,world!",脚本将看到它)。