PHP 获取访问者IP的方法

在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. {
  3. static $realip;
  4. if (isset($_SERVER)){
  5. if (isset($_SERVER["HTTP_X_FORWARDED_FOR"])){
  6. $realip = $_SERVER["HTTP_X_FORWARDED_FOR"];
  7. } else if (isset($_SERVER["HTTP_CLIENT_IP"])) {
  8. $realip = $_SERVER["HTTP_CLIENT_IP"];
  9. } else {
  10. $realip = $_SERVER["REMOTE_ADDR"];
  11. }
  12. } else {
  13. if (getenv("HTTP_X_FORWARDED_FOR")){
  14. $realip = getenv("HTTP_X_FORWARDED_FOR");
  15. } else if (getenv("HTTP_CLIENT_IP")) {
  16. $realip = getenv("HTTP_CLIENT_IP");
  17. } else {
  18. $realip = getenv("REMOTE_ADDR");
  19. }
  20. }
  21. return $realip;
  22. }

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

  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地址.