用户名:
密 码: 记住
您当前的位置:首页 > 网络编程 > php教程

PHP 获取访问者IP的方法

时间:2015-01-23  来源:西部数据  作者:西部数据

在php中自带了一个非常的简单的获取IP地址的全局变量,很多初学都获取IP都使用它了,但是对于这些我们一般用法是满足了,但是对于要求高精度这个函数还是不行的.

这个是最简单的方法,对于开了透明代理之类的是没有办法的,如果内网访问也不能读取正确的外网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地址,根据经验得出,代码如下:

  1. function getIP() 
  2.     static $realip
  3.     if (isset($_SERVER)){ 
  4.         if (isset($_SERVER["HTTP_X_FORWARDED_FOR"])){ 
  5.             $realip = $_SERVER["HTTP_X_FORWARDED_FOR"]; 
  6.         } else if (isset($_SERVER["HTTP_CLIENT_IP"])) { 
  7.             $realip = $_SERVER["HTTP_CLIENT_IP"]; 
  8.         } else { 
  9.             $realip = $_SERVER["REMOTE_ADDR"]; 
  10.         } 
  11.     } else { 
  12.         if (getenv("HTTP_X_FORWARDED_FOR")){ 
  13.             $realip = getenv("HTTP_X_FORWARDED_FOR"); 
  14.         } else if (getenv("HTTP_CLIENT_IP")) { 
  15.             $realip = getenv("HTTP_CLIENT_IP"); 
  16.         } else { 
  17.             $realip = getenv("REMOTE_ADDR"); 
  18.         }  
  19.     } 
  20.     return $realip

另外如果我们想获取更精准的使用第三方是一个不错的方法,代码如下:

  1. function get_onlineip() { 
  2.     $ch = curl_init('http://www.ip138.com/ip2city.asp'); 
  3.     curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); 
  4.     $a  = curl_exec($ch); 
  5.     preg_match('/[(.*)]/'$a$ip); 
  6.     return $ip[1]; 
  7.  } 

这样不管理代理还是什么都可以判断IP地址.

来顶一下
返回首页
返回首页
推荐资讯
WiFi太不安全:7岁女孩11分钟内入侵公共网络 WiFi太不安全:7岁女孩11分钟内入侵近期刚刚发布研究说WiFi网络能获得人们手机里多少私人信息,
不服跑个分?人工智能也出现“刷分”乱象 不服跑个分?人工智能也出现“刷分2014年,人工智能领域突然爆发,成为了科研和科技创业的热门
相关文章
    无相关信息
栏目更新
栏目热门