loading....

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::
/**
 * 检测访问的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
%>

 

posted on 2015-05-03 23:05  程序加载中  阅读(1973)  评论(0编辑  收藏  举报