网络编程
位置:首页>> 网络编程>> Asp编程>> 纯ASP(VBscript)写的全球IP地址搜索程序

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

  发布时间:2007-09-27 13:28:00 

标签:ip,搜索,asp

程序还不是很精简,以后再修改,程序所用的数据库为-- “冯志宏”-- 所写的--“追捕”--软件中所带IP数据库和“国华软件 Guohua Soft”的作者 --“冯国华”—所写的“全球IP地址分配表.chm”合二为一得到的。感谢“冯志宏”和“冯国华”提供的数据,数据库中还有不少的重复IP地址,希望有心人能将其删除,减小数据库。

我的程序写的还很笨拙,希望大家能多提意见,多多交流,谢谢!

取得的客户端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位相比较就可以查到正确的所在地。


<%@LANGUAGE="VBSCRIPT" CODEPAGE="936"%> 
  <html> 
  <head> 
  <title>Untitled Document</title> 
  <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
  </head> 
  <body> 
  <% 
   dim finishgetip,showip,allip 
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为读写 
   ’constr="Provider=microsoft.jet.oledb.4.0;"&"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") 
   ’constr="DRIVER={MICROSOFT ACCESS DRIVER (*.MDB)};DBQ="&SERVER.MAPPATH("allcon/#bbsall.mdb") 
   constr="Provider=microsoft.jet.oledb.4.0;"&"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})$"


 

0
投稿

猜你喜欢

  • 我们大家都知道CSS功能的强大,而有关CSS基本的排版控制虽然已有详细的使用说明和参考教程,但还有许多丰富的CSS排版能力,是很少能查到的。
  • 先让我们看一个例子,了解什么是模式化窗口。以下是QQ秀商城在非登录时提示登录的一种状态。当我在非登录状态,通过保存形象的方式买一件衣服时,弹
  • 随机背景--当你每次进入该页面时,从已指定的图片文件夹中,随机选取一个图片作为背景显示。这里介绍的方法是用ASP+CSS来实现的。 &nbs
  • 没事在这里发一下关于数据库大批量插入数据的效率对比,用ACCESS和MSSQL,数值是在本机测试,根据不同的环境和配置,数值可能会有较大差别
  • 有使用过VS2005开发工具的朋友或者其他语句如js中都有Try catch 语句块,那么在mysql中是否能有SQLserver的@@er
  • 开源的MySQL并不能取代非共享的私有数据库在企业中的应用,于是这些开源数据库的支持者们想把解决Web应用程序开发工具的可扩展性问题看作是获
  • set oSQLServer =server.createobject("SQLDMO.SQLServer")oSQLS
  • 1.字符串函数 长度与分析用 datalength(Char_expr) 返回字符串包含字符数,但不包含后面的空格 substring(ex
  • 以下的文章主要是介绍SQL Server数据库与其实际应用元数据,我前两天在相关网站看见SQL Server数据库与其实际应用元数据的资料,
  • 平面设计 常用尺寸 三折页广告 标准尺寸: (A4)210mm x 285mm普通宣传册 标准尺寸: (A4)210mm x 285mm文件
  • 同时在线访问量继续增大 对于1G内存的服务器明显感觉到吃力严重时甚至每天都会死机 或者时不时的服务器卡一下 这个问题曾经困扰了我半个多月My
  • 当点了链接后,跳出的网页地址是https://www.aspxhome.com/ 或https://www.cidianwang.
  • Filed under 数据库技术Leave a commentSQL Server命令行导数据两种方式bcp和sqlcmd先说一下bcp:
  • 在做数据库备份和还原数据库的时候出现"错误2812:未能找到存储过程’master.dbo.xp_fileexist’"
  • 在Web标准中一个很重要的概念就是强调页面的结构与表现分离。说的通俗一点就是XHTML中应该没有样式化的东西,而且Web在浏览器中除内容外都
  •  大家都出书,我也很幸运的有了这本书,不过一本书的好与坏,错与对都是在于一个人的理解,web标准这个东西主要还是大家理解,理解的深
  • The WeekdayName function returns the weekday name of a specified day o
  • 对于 link 元素 和 style 元素 我相信大家都比较了解,但对于他们的出现位置可能有误解。在 淘宝 的所有频道中出现这样一个问题:频
  • 如果在 Access 数据库中删除数据或对象,或者在 Access 项目中删除对象,Access 数据库或 Access 项目可能会产生碎片
  • 关于oracle 优化的内容很多,概念庞杂,不过可以总结出一个大纲性的东西作为需要考虑的方向,然后再逐步细化。oracle优化按重要性需要考
手机版 网络编程 asp之家 www.aspxhome.com