HTTP_CLIENT_IP
HTTP_X_FORWARD_IP
REMOTE_ADDR
依次探测? 还是有其他方法? 除了IP138?
下面的写法,用最严格的语法来看,有哪里不对,要怎么改?
<code> 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 get_onlineip(); } else { return $tip; } }</code>
或者用下面的函数?
<code>// 定义一个函数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; } </code>
HTTP_CLIENT_IP
HTTP_X_FORWARD_IP
REMOTE_ADDR
依次探测? 还是有其他方法? 除了IP138?
下面的写法,用最严格的语法来看,有哪里不对,要怎么改?
<code> 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 get_onlineip(); } else { return $tip; } }</code>
或者用下面的函数?
<code>// 定义一个函数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; } </code>
目前来说这种方式是最保险的。
ip138只能拿到访问者的IP,如果是服务器访问,就是服务器的IP
目前对这方面需求没有过多研究,正常工作中是使用依次探测的方式获取。
其实普通用户是不会刻意隐藏自己IP的. 也不会通过好几层的代理去访问你的服务. 所以依次判断这三个其实就可以了. 对普通用户而言, 这三个能拿到的IP的真实度也是蛮高的.
这个问题问的好,这个真不是个简简单单就能搞定的,客户端ip有些是存在欺骗和代理的问题,所以在获取的时候不是百分百的就能获取到的。不过如其他网友所说普通用户用代理什么的还是很少的。相信自己用自己的方法就可以,或者参考其他第三方获取ip的类库也可以