海南世纪云图网络科技有限公司
咨询热线:400-822-8458 客户服务:0898-32183600 无障碍阅读 适老模式

ASP屏蔽某个IP或IP段禁止访问网站

发表于:2009-12-21 00:00:00来源:易阳网络人气:3037

以下是引用片段:

可单独放置在某个页面或独立成一个文件进行调用

<%
        '受屏蔽IP地址(段)集合,星号为通配符,通常保存于配置文件中。
        Const BadIPGroup = "94.142.131.20|124.225.74.51|192.168.0.*|59.26.284.*"

        If IsForbidIP(BadIPGroup) = True Then
        Response.Write(GetIP &"系统已记录您的IP地址信息")
  Response.Write("<BR>")
        Response.Write("由于您在本站发布大量垃圾信息!管理员已禁止您访问站点。")
  Response.Write("<BR>")
        Response.Write("需要开通请联系")
        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
   %>

文章整理: 世纪云图  https://www.yuntop.cc/

以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

版权申明:本站文章部份来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!

特别注意:本站部份转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。

微信
网站建设
软件业务
网络营销
400电话