asp檢查ip地址是否為私有/內網ip地址源代碼。
內網/私有IP地址網段如下,還有127開頭的回環地址:
10.0.0.0-10.255.255.255
172.16.0.0—172.31.255.255
192.168.0.0-192.168.255.255
實現代碼:
<% function IpToNumber(ip)'IP地址轉為數字 arr=split(ip,".") IpToNumber=256*256*256*clng(arr(0))+256*256*clng(arr(1))+256*clng(arr(2))+clng(arr(3)) end function function IsPrivateIp(ip)'判斷給定的IP地址是否內網/私有ip地址 if instr(ip,"127.")=1 then'回環IP地址 IsPrivateIp=true:exit function end if ABegin=IpToNumber("10.0.0.0"):AEnd=IpToNumber("10.255.255.255")'A類私有IP地址 BBegin=IpToNumber("172.16.0.0"):BEnd=IpToNumber("172.31.255.255")'B類私有IP地址 CBegin=IpToNumber("192.168.0.0"):CEnd=IpToNumber("192.168.255.255")'C類私有IP地址 IpNum=IpToNumber(ip) IsPrivateIp=(ABegin<=IpNum and IpNum<=AEnd) or (BBegin<=IpNum and IpNum<=BEnd) or (CBegin<=IpNum and IpNum<=CEnd) end function Response.Write IsPrivateIp("11.255.255.255")&"<br>"'false Response.Write IsPrivateIp("182.255.255.255")&"<br>"'false Response.Write IsPrivateIp("172.30.255.255")&"<br>"'true Response.Write IsPrivateIp("192.168.205.2")&"<br>"'true Response.Write IsPrivateIp("127.168.205.2")'true %>