如何获取伪装ip下的真实ip地址

取客户端ip其实不是个简单的活儿,因为存在Ip欺骗,和代理问题,所以获取客户端的IP的真实性会打折扣的,不能百分百准确.但是我们还是尽量找一个比较完善的获取客户端真正ip方法.使用php获取IP的方法能找到很多.


php获取用户(客户端)真实IP地址的三种方法

01function get_real_ip(){
02    $ip=false;
03    if(!empty($_SERVER['HTTP_CLIENT_IP'])){
04        $ip=$_SERVER['HTTP_CLIENT_IP'];
05    }
06    if(!empty($_SERVER['HTTP_X_FORWARDED_FOR'])){
07        $ips=explode (', '$_SERVER['HTTP_X_FORWARDED_FOR']);
08        if($ip){ array_unshift($ips$ip); $ip=FALSE; }
09        for ($i=0; $i count($ips); $i++){
10            if(!eregi ('^(10│172.16│192.168).'$ips[$i])){
11                $ip=$ips[$i];
12                break;
13            }
14        }
15    }
16    return ($ip $ip $_SERVER['REMOTE_ADDR']);
17}

第二种方法:

01function get_real_ip(){
02    static $realip;
03    if(isset($_SERVER)){
04        if(isset($_SERVER['HTTP_X_FORWARDED_FOR'])){
05            $realip=$_SERVER['HTTP_X_FORWARDED_FOR'];
06        }else if(isset($_SERVER['HTTP_CLIENT_IP'])){
07            $realip=$_SERVER['HTTP_CLIENT_IP'];
08        }else{
09            $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;
21}

第三种方法,摘自DISCUZ,应该还不错吧!

01// 获取IP地址(摘自discuz)
02function getIp(){
03    $ip='未知IP';
04    if(!empty($_SERVER['HTTP_CLIENT_IP'])){
05        return is_ip($_SERVER['HTTP_CLIENT_IP'])?$_SERVER['HTTP_CLIENT_IP']:$ip;
06    }elseif(!empty($_SERVER['HTTP_X_FORWARDED_FOR'])){
07        return is_ip($_SERVER['HTTP_X_FORWARDED_FOR'])?$_SERVER['HTTP_X_FORWARDED_FOR']:$ip;
08    }else{
09        return is_ip($_SERVER['REMOTE_ADDR'])?$_SERVER['REMOTE_ADDR']:$ip;
10    }
11}
12function is_ip($str){
13    $ip=explode('.',$str);
14    for($i=0;$i<count($ip);$i++){ 
15        if($ip[$i]>255){ 
16            return false; 
17        
18    
19    return preg_match('/^[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}$/',$str); 
20}
  • 0
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值