凹丫丫网络社区's Archiver

noodles 发表于 2008-3-12 17:09

纯ASP(VBscript)写的全球IP地址搜索程序

<[email=%@LANGUAGE=]%@LANGUAGE="VBSCRIPT[/email]" CODEPAGE="936"%>
  <html>
  <head>
  <title>Untitled Document</title>
  <meta http-equiv="Content-Type" c>
  </head>
  <body>
  <%
   dim finishgetip,showip,allip
  '/////////////////////////////////////////////////////////
  '程序还不是很精简,以后再修改
  '本程序所用的数据库为-- “冯志宏”-- 所写的--“追捕”--软件中所带IP数
据库和
  ' “国华软件 Guohua Soft”的作者 --“冯国华”—所写的“全球IP地址分配
表.chm”合二为一得到的
  '感谢“冯志宏”和“冯国华”提供的数据
  '数据库中还有不少的重复IP地址,希望有心人能将其删除,减小数据库
  '我的程序写的还很笨拙,希望大家能多提意见,多多交流,谢谢!
  '///////////////////////////////////////////////////////////
  '解决思路: [url=http://www.knowsky.com]www.knowsky.com[/url]
  '取得的客户端IP一般是202.11.25.1这种,而数据库中的IP格式为
202.011.025.001,这就需要将取得的
  '客户端IP转换为与数据库中IP一样的格式
  '因为目前我们所用的IP是分为4段,每段3位,中间以“.”分隔
  '所以我的思路是将客户端IP以“.”符号分割为4段,即202/11/25/1
  '然后再分别核对每一段,如果是3位,则不变;如不足3位,为2位,该段前补1
个0,为1,同理,则补2个0
  '得到格式化后的IP后,去掉IP的最后一段,即取包括“.”的前11位,与数据
库中的startip字段的前11位相比较,查找相同的值
  '因为从数据库中可以看到,startip和endip的前三段都是一样的,而最后一段
不过是内部子网地址,可以去掉
  '所以只要取startip或endip的任意一个字段的前11位与客户端IP的前11位相比
较就可以查到正确的所在地
  '///////////////////////////////////////////////////////////////
  function checkip_trueip()
   '取客户端真实IP
   getclientip = Request.ServerVariables("HTTP_X_FORWARDED_FOR") '如果
客户端用了代理服务器,则用Request.ServerVariables("REMOTE_ADDR")方法只
能得到空值,则应该用ServerVariables("HTTP_X_FORWARDED_FOR")方法
   If getclientip = "" Then
   getclientip = Request.ServerVariables("REMOTE_ADDR")'如果客户端没用
代理,则Request.ServerVariables("HTTP_X_FORWARDED_FOR")得到是空值,应该
用Request.ServerVariables("REMOTE_ADDR")方法
   end if
  checkip_trueip = getclientip
  end function
  '/////////////////////////////////////////////////////////
  function getaccessrecordset(db,sql,mark,read)'取得Recordset对象
   set conn=getaccessconn(db)'输入参数为db-数据库的相对路径,sql-SQL语
句,mark,read为数据库读取方式,1,1为只读,1,3为读写
   'c&"data
Source="&Server.MapPath(db)
   ' conn.open constr
   set getaccessrecordset=server.CreateObject("ADODB.Recordset")
   getaccessrecordset.open sql,conn,mark,read
   End function
  '////////////////////////////////////////////////////////////
  function getaccessconn(db)'取得connection对象
  set getaccessconn=server.CreateObject("ADODB.Connection")
   'c&SERVER.MAPPATH("allcon/#bbsall.mdb")
   c&"data
Source="&Server.MapPath(db)
   getaccessconn.open constr
   end function
  '////////////////////////////////////////////////////////////
  dim getip
  'getip=(trim(request.ServerVariables("REMOTE_ADDR")))'从客户端获取IP
  'getip=(trim(request.QueryString("comes"))) '自己输入IP测试
  'response.Write(getip&"<br>")
  '////////////////////////////////////////////////////////////
  function checkip_locations(checkstring) '返回IP中分隔字符的位置函数
   checkip_locations=Instr(checkstring,".") '将位置的值赋予给函数
  end function
  '////////////////////////////////////////////////////////////
  '以下函数为分割IP,取得每次分割后“.”符号右边的IP剩余的字符串
  function checkip_left(checkstring)
   locations_left=checkip_locations(checkstring) '得到在IP剩余的字符串
中“.”第一次出现的位置
   iplength_left=Len(checkstring) '取得IP剩余的字符串的长度
   divide_locations_left=iplength_left-locations_left '取得在IP剩余的字
符串中“.”第一次出现的位置,从右往左数是多少位
   ipstr_left=Right(checkstring,divide_locations_left) '取得本次分割后,
“.”符号右边的IP剩余的字符串
   checkip_left=ipstr_left '将上面得到的字符串赋给函数
  end function
  '///////////////////////////////////////////////////////////
  '以下函数为分割IP,取得每次分割后“.”符号左边的IP字符串,即将IP分为四
段,每一段的字符串
   
  function checkip_right(checkstring)
   locations_right=checkip_locations(checkstring) '取得在IP中“.”第一
次出现的位置
   iplength_right=Len(checkstring) '取得IP字符串长度
   divide_locations_right=iplength_right-locations_right '取得在IP剩余
的字符串中“.”第一次出现的位置,从右往左数是多少位
   ipstr11=Trim(Replace(Left(checkstring,locations_right),".","")) '将
得到的“.”左边的字符串去掉"."符号
   '如果IP分为4段后每一段不足3位则补0
   if Len(ipstr11)="2" then ipstr11="0"&ipstr11
   if Len(ipstr11)="3" then ipstr11=ipstr11
   if Len(ipstr11)="1" then ipstr11="00"&ipstr11
   checkip_right=ipstr11 '得到“.”符号之前的字符串,即本次分割后得到的
IP分割为四段后其中的一段
  end function
   
  '/////////////////////////////////////////////////////////
  '检查IP是否为内部网IP
  '我写的判断是以:127.0.0.0-127.XXX.XXX.255和192.0.0.0-192.XXX.XXX.255
为依据,如果为这二者,则是内部网IP,反之为外部网
  '判断内部IP的依据是什么,我也不清楚,所以这里要高手多多指点,并加以修
正,与我联系
  function checkiplocal(checkstring)
   dim re1
   set re1=new RegExp '取得正则表达式对象
   're1.pattern中的表达式为,内部网的IP应为127或192开头,中间为0-9中任意
1-3个数字加"."组成一段
   re1.pattern="^(127\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3})|(192\.[0-9]
{1,3}\.[0-9]{1,3}\.[0-9]{1,3})$"
re1.global=false
   re1.Ignorecase=false
   checkiplocal=re1.test(checkstring)
   set re1=nothing
  end function
  
'//////////////////////////////////////////////////////////////////////
  function checkip_remote(checkstring)
   dim iplength 'IP字符串的长度
   dim locations '"."字符出现的位置
   iplength=Len(checksting)
   locations=Instr(checkstring,".") '从左到右检索“.”符号在IP字符串中
第一次出现的位置
   '以“.”字符将IP分割为4段
   locations2=iplength-locations
   ipstring1=Left(checkstring,locations)
   ipstring2=Right(checkstring,locations2)
  end function
  '/////////////////////////////////////////////////////////
  '/////////////////////////////////////////////////////////
  ipinfo_local="您的IP是内部网IP!"
   ipinfo_remote="外部网IP!"
   getip=checkip_trueip()
   currentip=checkiplocal(getip) '调用checkiplocal()函数对得到的IP进
行检查,确定是内部网地址还是外部网地址
   'if currentip=true then'测试代码
   'response.Write(ipinfo_local)
   if currentip=true then '为假
   response.Write(ipinfo_local)'说明为内部网IP
   else
   '进行转换
   '以下为循环提取并按位补0将IP分为4段
   locations=checkip_locations(getip)'取得“.”在第一次分割前在IP中第一
次出现的位置
   iplength=Len(getip) '取得客户端IP的长度
   divide_locations=iplength-locations '取得将客户端IP从右向左数到IP从
左往右数第一个“.”的位置
   ipstr1=Trim(Replace(Left(getip,locations),".",""))
   ipstr2=Right(getip,divide_locations)'取得第一次分割后客户端右边剩下
的数值
   '如果IP分为4段后每一段不足3位则补0
   if Len(ipstr1)="2" then ipstr1="0"&ipstr1 '长度为二,不足三位,在字
符串之前补一个0
   if Len(ipstr1)="3" then ipstr1=ipstr1 '据上类推
   if Len(ipstr1)="1" then ipstr1="00"&ipstr1 '这时的ipstr1为IP的第一段
   
   ipstr12=checkip_right(ipstr2) '这时的ipstr12为IP的第二段
   ipstr122=checkip_left(ipstr2)
   ipstr13=checkip_right(ipstr122) '这时的ipstr13为IP的第三段
   ipstr14=checkip_left(ipstr122) '这时的ipstr14为IP的第四段
   if Len(ipstr14)="1" then ipstr14="00"&ipstr14 '对得到的IP的第四段进
行补0,此步骤可不要
   if Len(ipstr14)="2" then ipstr14="0"&ipstr14
   if Len(ipstr14)="3" then ipstr14=ipstr14
   
   'response.write ipstr1&"<br>" '写出IP分割后的每段的值
   'response.write ipstr12&"<br>"
   'response.write ipstr13&"<br>"
   'response.write ipstr14
   allip=ipstr1&"."&ipstr12&"."&ipstr13&"."&ipstr14
   finishgetip=left(allip,11)
   dim ipaddr,iplocal,sqls
   '以下SQL语句为提取startip字段左边11位值是否等于客户端IP的左边的11位
的值
   sqls="SELECT country_state,areauser FROM ip WHERE Left(startip,11)
='"&finishgetip&"'"
   set rs=getaccessrecordset("#worldip.mdb",sqls,"1","1") '得到查询值
   if rs.eof then '如果没找到与客户端IP相等的值
   showip=checkip_trueip() '把客户端IP赋予showip
   ipaddr="未知地区" '国家或省份
   iplocal="未知地点" '具体的地方
   else
   showip=checkip_trueip()
   ipaddr=rs("country_state")
   iplocal=rs("areauser")
   end if
   'response.write("您的IP是:"&showip&" ")
   'response.write("您来自:"&ipaddr&" ")
   'response.write("您是:"&iplocal)
   rs.close
   set rs=nothing
   %>
   <%="您的IP是:"&showip&" "%>
   <%="您来自:"&ipaddr&" "%>
   <%="您是:"&iplocal&"<br>"%>
   
  如果IP地址有错误,请与我联系,或下载数据库更正,谢谢!<br>
  <table width="760" border="0" cellspacing="0" cellpadding="0">
   <tr>
   <td width="203"><a href="Script56.rar">下载Script56.CHM</a>--
>1.34M</td>
   <td width="548">简介:Microsoft的帮助文档,有VBscript语法,JScript语
法,正则表达式  </td>
   <td width="3"> </td>
   <td width="6"> </td>
   </tr>
   <tr>
   <td> </td>
   <td> </td>
   <td> </td>
   <td> </td>
   </tr>
   <tr>
   <td><a href="ipsearch.rar">下载ASP全球IP地址搜索程序</a></td>
   <td>ASP+ACCESS    大小401K;格式rar</td>
   <td> </td>
   <td> </td>
   </tr>
   <tr>
   <td> </td>
   <td><font color="#000099"> </font> <font color="#0000FF">
</font></td>
   <td> </td>
   <td> </td>
   </tr>
   <tr>
   <td>如果你的IP是未知,如果你愿意,请提交你的所在地:</td>
   <td>
   <form name="form1" method="post" action="postip.asp">
   <table width="100%" border="1" cellspacing="0" cellpadding="0">
   <tr>
   <td width="21%"> 省份: </td>
   <td width="44%">
   <input type="text" name="country_state">
   </td>
   <td width="35%"> </td>
   </tr>
   <tr>
   <td width="21%">具体所在地或是什么网的用户:</td>
   <td width="44%">
   <input type="text" name="areauser">
   </td>
   <td width="35%">例如:北京清华大学或北京网通用户</td>
   </tr>
   <tr>
   <td width="21%"> </td>
   <td width="44%">
   <input type="hidden" name="startip" value="<%=finishgetip&".000"%>">
   <input type="hidden" name="endip" value="<%=finishgetip&".255"%>">
   </td>
   <td width="35%"> </td>
   </tr>
   <tr>
   <td width="21%"> </td>
   <td width="44%">
   <input type="submit" name="Submit" value="提交">
   </td>
   <td width="35%"> </td>
   </tr>
   </table>
   </form>
   </td>
   <td> </td>
   <td> </td>
   </tr>
  </table>
   <%
   end if
   %>
  </body>
  </html>

页: [1]

Powered by Discuz! Archiver 7.0.0  © 2001-2007 Comsenz Inc.