zoukankan      html  css  js  c++  java
  • ASP和PHP限制IP访问 只允许指定IP访问 允许*号通配符过滤IP

    /**
     * 检测访问的ip是否为规定的允许的ip
     * Enter description here ...
     */
    function check_ip(){
        $ALLOWED_IP=array('192.168.2.*','127.0.0.1','192.168.2.49');
        $IP=getIP();
        $check_ip_arr= explode('.',$IP);//要检测的ip拆分成数组
        #限制IP
        if(!in_array($IP,$ALLOWED_IP)) {
            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则找到有一个匹配成功的就返回
                         return;
                         die;
                     }
                }
            }//end foreach
            header('HTTP/1.1 403 Forbidden');
            echo "Access forbidden";
            die;
        }
    }
    function getIP() {
        return isset($_SERVER["HTTP_X_FORWARDED_FOR"])?$_SERVER["HTTP_X_FORWARDED_FOR"]
        :(isset($_SERVER["HTTP_CLIENT_IP"])?$_SERVER["HTTP_CLIENT_IP"]
        :$_SERVER["REMOTE_ADDR"]);
    }

     以下为ASP版:

    <%
    '受屏蔽IP地址(段)集合,星号为通配符,通常保存于配置文件中。
    Const BadIPGroup = "192.168.1.*|202.68.*.*|*.12.55.34|185.*.96.24|127.*.0.1|192.168.0.1"
    If IsForbidIP(BadIPGroup) = True Then
        Response.Write(GetIP &"IP地址禁止访问")
        Response.End()
    End If
    
    '参数vBadIP:要屏蔽的IP段,IP地址集合,用|符号分隔多个IP地址(段)
    '返回Bool:True用户IP在被屏蔽范围,False 反之
    Function IsForbidIP(vBadIP)
        Dim counter, arrIPPart, arrBadIP, arrBadIPPart, i, j
        arrBadIP = Split(vBadIP, "|")
        arrIPPart = Split(GetIP(), ".")
        For i = 0 To UBound(arrBadIP)
        counter = 0
        arrBadIPPart = Split(arrBadIP(i), ".")
        For j = 0 To UBound(arrIPPart)
        If(arrBadIPPart(j)) = "*" or Cstr(arrIPPart(j)) = Cstr(arrBadIPPart(j)) Then
        counter = counter + 1
        End If
        Next
        If counter = 4 Then
        IsForbidIP = True
        Exit Function
        End If
        Next
        IsForbidIP = False
    End Function
    
    ''返回客户IP地址
    Function GetIP()
        Dim IP
        IP = Request.ServerVariables("HTTP_X_FORWARDED_FOR")
        If IP = "" Then IP = Request.ServerVariables("REMOTE_ADDR")
        GetIP = IP
    End Function
    %>
  • 相关阅读:
    JetBrains全系列破解
    BZOJ 4817: [Sdoi2017]树点涂色 LCT + DFS序 + 线段树
    LOJ #6041. 「雅礼集训 2017 Day7」事情的相似度 LCT + SAM + 线段树
    Uoj 52. 【UR #4】元旦激光炮 交互题
    Uoj #218. 【UNR #1】火车管理 可持久化线段树+思维
    luoguP3979 遥远的国度 LCT + multiset维护子树信息
    BZOJ 4999: This Problem Is Too Simple! DFS序 + LCA + 树状数组 + 离线
    BZOJ 1787: [Ahoi2008]Meet 紧急集合
    BZOJ 2959: 长跑 LCT + 并查集 + 点双
    BZOJ 4259: 残缺的字符串 FFT
  • 原文地址:https://www.cnblogs.com/mssql8/p/4474983.html
Copyright © 2011-2022 走看看