这个是最简单的方法,对于开了透明代理之类的是没有办法的,如果内网访问也不能读取正确的外网ip,不过很省力就是了:
代码如下 复制代码
$ip = $_server[remote_addr];
搞定~
上面方法用来取得客户端的 ip 地址,但如果客户端是使用代理服务器来访问,那取到的就是代理服务器的 ip 地址,而不是真正的客户端 ip 地址
要想透过代理服务器取得客户端的真实 ip 地址,就要使用 getenv(http_x_forwarded_for) 来读取。
但是如果客户端没有通过代理服务器来访问,那么用getenv(http_x_forwarded_for) 取到的值将是空的。
代码如下 复制代码
else if(getenv(http_x_forwarded_for))
$ip = getenv(http_x_forwarded_for);
表示如果getenv(http_x_forwarded_for) 取到的值存在不为空(即客户端使用代理服务器的情况下),则变量$ip等于getenv(http_x_forwarded_for) 取到的真实ip值。
如果上面的else if(getenv(http_x_forwarded_for))取得的值为空(即没有使用代理服务器),则不会执行下面的$ip = getenv(http_x_forwarded_for);这一行语句。
这种情况下已经确认客户端没有使用代理服务器,从而通过
代码如下 复制代码
else if(getenv(remote_addr))
$ip = getenv(remote_addr);
这两行语句获得客户端的ip地址也是真实的ip地址,根据经验得出
代码如下 复制代码
function getip()
{
static $realip;
if (isset($_server)){
if (isset($_server[http_x_forwarded_for])){
$realip = $_server[http_x_forwarded_for];
} else if (isset($_server[http_client_ip])) {
$realip = $_server[http_client_ip];
} else {
$realip = $_server[remote_addr];
}
} else {
if (getenv(http_x_forwarded_for)){
$realip = getenv(http_x_forwarded_for);
} else if (getenv(http_client_ip)) {
$realip = getenv(http_client_ip);
} else {
$realip = getenv(remote_addr);
} www.111cn.net
}
return $realip;
}
另外如果我们想获取更精准的使用第三方是一个不错的方法哦
代码如下 复制代码
function get_onlineip() {
$ch = curl_init('http://www.ip138.com/ip2city.asp');
curl_setopt($ch, curlopt_returntransfer, true);
$a = curl_exec($ch);
preg_match('/[(.*)]/', $a, $ip);
return $ip[1];
}
这样不管理代理还是什么都可以判断ip地址哦