在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地址,根据经验得出

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");
    } 
  }
  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地址哦

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持www.887551.com。