HTTP_CLIENT_IP
HTTP_X_FORWARD_IP
REMOTE_ADDR
依次探测? 还是有其他方法? 除了IP138?
下面的写法,用最严格的语法来看,有哪里不对,要怎么改?
function Getip() {
if (!empty($_SERVER["HTTP_CLIENT_IP"])) {
$ip = $_SERVER["HTTP_CLIENT_IP"];
}
if (!empty($_SERVER['HTTP_X_FORWARDED_FOR'])) {//获取代理ip
$ips = explode(',', $_SERVER['HTTP_X_FORWARDED_FOR']);
}
if ($ip) {
$ips = array_unshift($ips, $ip);
}
$count = count($ips);
for ($i = 0; $i < $count; $i++) {
if (!preg_match("/^(10|172\.16|192\.168)\./i", $ips[$i])) {//排除局域网ip
$ip = $ips[$i];
break;
}
}
$tip = $ip ? $ip : $_SERVER['REMOTE_ADDR'];
if ($tip == "127.0.0.1") {//获得本地真实IP
return $this -> get_onlineip();
} else {
return $tip;
}
}
或者用下面的函数?
// 定义一个函数getIP()
function getIP()
{
global $ip;
if (getenv("HTTP_CLIENT_IP"))
$ip = getenv("HTTP_CLIENT_IP");
else if(getenv("HTTP_X_FORWARDED_FOR"))
$ip = getenv("HTTP_X_FORWARDED_FOR");
else if(getenv("REMOTE_ADDR"))
$ip = getenv("REMOTE_ADDR");
else
$ip = "Unknow";
return $ip;
}
目前来说这种方式是最保险的。
ip138只能拿到访问者的IP,如果是服务器访问,就是服务器的IP