亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

純ASP(VBscript)寫的全球IP地址搜索程序

2019-11-18 19:56:32
字體:
來源:轉載
供稿:網友

<%@LANGUAGE="VBSCR<html>
<head>
<title>Untitled Document</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>
<body>
<%
  dim finishgetip,showip,allip
'/////////////////////////////////////////////////////////
'程序還不是很精簡,以后再修改
'本程序所用的
數據庫為-- “馮志宏”-- 所寫的--“追捕”--軟件中所帶IP數據庫和
' “國華軟件 Guohua Soft”的作者 --“馮國華”—所寫的“全球IP地址分配表.chm”合二為一得到的
'感謝“馮志宏”和“馮國華”提供的數據
'數據庫中還有不少的重復IP地址,希望有心人能將其刪除,減小數據庫
'我的程序寫的還很笨拙,希望大家能多提意見,多多交流,謝謝!
'///////////////////////////////////////////////////////////
'解決思路: www.49028c.com
'取得的客戶端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為讀寫
      'constr="     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})$"
  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&"&nbsp;")
   'response.write("您來自:"&ipaddr&"&nbsp;")
   'response.write("您是:"&iplocal)
   rs.close
     set rs=nothing
  %>
   <%="您的IP是:"&showip&"&nbsp;"%>
   <%="您來自:"&ipaddr&"&nbsp;"%>
   <%="您是:"&iplocal&"<br>"%>
 
如果IP地址有錯誤,請與我聯系,或下載數據庫更正,謝謝!<br>
<table width="760" border="0" cellspacing="0" cellpadding="0">
  <tr>
    <td width="203"><a href="Script56.rar">下載Script56.CHM</a>--&gt;1.34M</td>
    <td width="548">簡介:Microsoft的幫助文檔,有VBscript語法,JScript語法,正則表達式&nbsp;&nbsp;</td>
    <td width="3">&nbsp;</td>
    <td width="6">&nbsp;</td>
  </tr>
  <tr>
    <td>&nbsp;</td>
    <td>&nbsp;</td>
    <td>&nbsp;</td>
    <td>&nbsp;</td>
  </tr>
  <tr>
    <td><a href="ipsearch.rar">下載
asp全球IP地址搜索程序</a></td>
    <td>ASP+ACCESS&nbsp;&nbsp;&nbsp;&nbsp;大小401K;格式rar</td>
    <td>&nbsp;</td>
    <td>&nbsp;</td>
  </tr>
  <tr>
    <td>&nbsp;</td>
    <td><font color="#000099">&nbsp;</font>&nbsp;<font color="#0000FF">&nbsp;</font></td>
    <td>&nbsp;</td>
    <td>&nbsp;</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%">&nbsp;</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%">&nbsp;</td>
            <td width="44%">
              <input type="hidden" name="startip" value="<%=finishgetip&".000"%>">
              <input type="hidden" name="endip" value="<%=finishgetip&".255"%>">
            </td>
            <td width="35%">&nbsp;</td>
          </tr>
          <tr>
            <td width="21%">&nbsp;</td>
            <td width="44%">
              <input type="submit" name="Submit" value="提交">
            </td>
            <td width="35%">&nbsp;</td>
          </tr>
        </table>
      </form>
    </td>
    <td>&nbsp;</td>
    <td>&nbsp;</td>
  </tr>
</table>
  <%
  end if
  %>
</body>
</html>

演示地址:http://www.49028c.com/ip


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲高清福利视频| 日韩人在线观看| 精品中文字幕久久久久久| 性视频1819p久久| 亚洲精品720p| 亚洲精品自拍视频| 国产成人在线一区| 1769国产精品| 亚洲精品天天看| 国产精品国产三级国产专播精品人| 国产精品吊钟奶在线| 最近中文字幕2019免费| 色狠狠av一区二区三区香蕉蜜桃| 精品成人69xx.xyz| 日韩美女免费视频| 国产亚洲a∨片在线观看| 日本精品视频在线播放| 亚洲一区二区三区xxx视频| 亚洲xxxx在线| 欧美中文字幕精品| 欧美成人四级hd版| 色综合久久久久久中文网| 91探花福利精品国产自产在线| 久久91精品国产| 久久精品99国产精品酒店日本| 91国自产精品中文字幕亚洲| 亚洲欧美一区二区三区在线| 91极品视频在线| 亚洲男女自偷自拍图片另类| 精品国产成人在线| 久青草国产97香蕉在线视频| 欧美国产日韩一区二区在线观看| 伊人伊人伊人久久| 日韩高清电影免费观看完整版| 欧美丝袜第一区| 亚洲精品一区二区网址| 国产成人精品av在线| 欧美巨猛xxxx猛交黑人97人| 精品亚洲aⅴ在线观看| 91精品成人久久| 国产精品久久久久影院日本| 成人97在线观看视频| 中文字幕精品视频| 欧美日韩国产麻豆| 久久中国妇女中文字幕| 久久久亚洲欧洲日产国码aⅴ| 国产视频精品免费播放| 国产精品流白浆视频| 欧美国产日韩中文字幕在线| 亚洲毛片在线观看.| 久久69精品久久久久久久电影好| 欧美日韩国产一区中文午夜| 成人福利视频在线观看| 日本一区二区不卡| 色天天综合狠狠色| 亚洲国产黄色片| 91精品综合久久久久久五月天| 久久91精品国产| 97精品一区二区视频在线观看| 在线观看亚洲区| 亚洲国产成人精品久久久国产成人一区| 4438全国成人免费| 亚洲性生活视频在线观看| 国产精品视频一区国模私拍| 亚洲女人初尝黑人巨大| 久久久久久久久久久网站| 欧美成人午夜激情视频| 欧美激情视频免费观看| 日韩在线欧美在线国产在线| 精品国产一区二区三区在线观看| 国产精品 欧美在线| 日本韩国在线不卡| 91av视频在线观看| 国产国语videosex另类| 亚洲高清福利视频| 亚洲精品在线视频| 欧美性猛交xxxx乱大交蜜桃| 一个色综合导航| 亚洲91精品在线观看| 2018日韩中文字幕| 久久久精品免费视频| 久久免费视频这里只有精品| 日韩成人在线视频| 亚洲欧美日韩一区二区在线| 国产在线久久久| 久久久久久久影院| www.日韩.com| 茄子视频成人在线| 狠狠久久亚洲欧美专区| 成人福利网站在线观看11| 日韩av中文字幕在线播放| 97碰碰碰免费色视频| 国产999视频| 国产精品一区二区av影院萌芽| 国产日韩综合一区二区性色av| 日韩动漫免费观看电视剧高清| 亚洲男人第一av网站| 亚洲香蕉伊综合在人在线视看| 久久天天躁日日躁| 亚洲精品国产拍免费91在线| 久久久视频免费观看| 亚洲精品日韩丝袜精品| 日本aⅴ大伊香蕉精品视频| 中文日韩在线观看| 亚洲第一免费网站| 精品久久久久久亚洲精品| 浅井舞香一区二区| 久久久亚洲影院你懂的| 成人妇女淫片aaaa视频| 久久久精品一区| 91亚洲永久免费精品| 国产欧美久久久久久| 欧美成人剧情片在线观看| 俺去亚洲欧洲欧美日韩| 国产91色在线播放| 91精品久久久久久综合乱菊| 国产精品爽爽ⅴa在线观看| 国产成人精品久久久| 懂色av中文一区二区三区天美| 中文字幕成人精品久久不卡| 久久久久久中文| 亚洲精品白浆高清久久久久久| 福利二区91精品bt7086| 热久久99这里有精品| 国产日韩在线视频| 成人免费大片黄在线播放| 日韩av大片在线| 国产精品精品久久久久久| 久久99久久久久久久噜噜| 日韩成人中文电影| 亚洲欧美日韩久久久久久| 国产一区在线播放| 精品久久久久久亚洲精品| 国产视频久久久久久久| 欧美xxxx18性欧美| 热99精品里视频精品| 亚洲久久久久久久久久久| 亚洲精品久久久久久久久久久久| 亚洲精品国产成人| 5566成人精品视频免费| 久久国产精品久久久| 久久精品99久久久香蕉| 久久国内精品一国内精品| 国产热re99久久6国产精品| 久久的精品视频| 欧美大荫蒂xxx| 国产精品一区二区久久| 亚洲人午夜精品| 国产免费一区二区三区在线观看| 国产97人人超碰caoprom| 国产精品久久久一区| 日韩高清欧美高清| 亚洲成人a级网| 91亚洲精品在线观看| 中文字幕日本欧美| 亚洲综合精品一区二区| 欧美激情在线有限公司| 欧美成人精品h版在线观看| 精品国偷自产在线视频99| 98精品国产高清在线xxxx天堂| 欧美插天视频在线播放| 欧美性一区二区三区| 国产女人18毛片水18精品| 国产亚洲精品久久久久久|