以下是引用zzy_420在2010-4-11 21:29:38的发言:
用 server 获取浏览者的IP地址,再截取其相应的 IP 段,再与自己想要限制的IP段相比较或者看其是否是自己允许访
问的IP段,之后根据需要 动态输出新闻列表。字段source中的内容为不知道楼主根据什么条件设置。
字段source的内容就是汉字“允许”2个字
程序代码:
<%
'限制IP地址(段)集合,星号为通配符。
Const BadIPGroup = "10.117.29.*"
If IsForbidIP(BadIPGroup) = False Then
Response.Write("<br><br><p align=center><font size=6>无访问权限</font></p>")
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
%>
此段代码能单独限制ip段,但是如何与source相结合使用?最好能给出完整代码,谢谢