php 限制ip访问

    //限制ip访问
    public function ip_test(){
        //获取客户端ip
        if (getenv("HTTP_CLIENT_IP"))
            $ip = getenv("HTTP_CLIENT_IP");
        else if(getenv("HTTP_X_FORWARDED_FOR"))
            $ip = getenv("HTTP_X_FORWARDED_FOR");
        else if(getenv("REMOTE_ADDR"))
            $ip = getenv("REMOTE_ADDR");
        else $ip = "Unknow";
        $ALLOWED_IP = array('10.144.39.132');
        //允许访问的ip
        $check_ip_arr= explode('.',$ip);
        //ip参数拆分成数组
        if(!in_array($ip,$ALLOWED_IP)) {
            $bl=false;
            foreach ($ALLOWED_IP as $val){
                if(strpos($val,'*')!==false){
                    //发现有*号替代符
                    $arr=array();
                    $arr=explode('.', $val);
                    $bl=true;
                    //用于记录循环检测中是否有匹配成功的
                    for ($i=0;$i<4;$i++){
                        if($arr[$i]!='*'){
                            //不等于* 就要进来检测,如果为*符号替代符就不检查
                            if($arr[$i]!=$check_ip_arr[$i]){
                                $bl=false;
                                break;
                                //终止检查本个ip 继续检查下一个ip
                            }
                        }
                    }
                    //end for
                    if($bl){
                        //如果是true则终止匹配
                        break;
                    }
                }
            }
            //end foreach
            if(!$bl){
                $return=array(
                    'status'=>2,
                    'msg'=>'该IP无权限访问',
                    'data'=>$ip
                );
                echo json_encode($return);
                exit();
            }
        }else{
            echo '可以访问';
        }
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值