ASP 精華源碼收集(五年總結(jié))第18/20頁
更新時間:2008年10月20日 22:58:16 作者:
在5年的開發(fā)中,總結(jié)出來的一些源碼
'────────────────────────────────
'IP 效驗
Public Function Valid_IP(ByVal IP)
Dim i
Dim dot_count
Dim test_octet
Dim byte_check
IP = Trim(IP)
' 確認IP長度
If Len(IP) < &H08 Then
Valid_IP = False
'顯示錯誤提示
Exit Function
End If
i = &H01
dot_count = &H00
For i = 1 To Len(IP)
If Mid(IP, i, &H01) = "." Then
' 增加點的記數(shù)值
' 并且設置text_octet 值為空
dot_count = dot_count + &H01
test_octet = ""
If i = Len(IP) Then
' 如果點在結(jié)尾則IP效驗失敗
Valid_IP = False
' 顯示錯誤提示
Exit Function
End If
Else
test_octet = test_octet & Mid(IP, i, &H01)
' 使用錯誤屏蔽來檢查數(shù)據(jù)段值的正確性
On Error Resume Next
' 進行強制類型轉(zhuǎn)換
' 如果轉(zhuǎn)換失敗就可通過檢查Err是否為真來確認
byte_check = CByte(test_octet)
If (Err) Then
' 強制類型轉(zhuǎn)換產(chǎn)生錯誤
' 所取段值的數(shù)據(jù)不為數(shù)值
' 或所取段值的數(shù)據(jù)長度大于&HFF
' 則類型不為byte類型
' IP 地址的正確性為假
Valid_IP = False
Exit Function
End If
End If
Next
' 通過上一步的驗證,現(xiàn)在應該要檢查小點是否有3個
If dot_count <> &H03 Then
Valid_IP = False
Exit Function
End If
' 一切正常,那么該IP為正確的IP地址
Valid_IP = True
End Function
'────────────────────────────────
' 轉(zhuǎn)換一個數(shù)值為IP
Public Function CStringIP(ByVal anNewIP)
Dim lsResults
Dim lnTemp
Dim lnIndex
For lnIndex = &H03 To &H00 Step -&H01
lnTemp = Int(anNewIP / (&H100 ^ lnIndex))
lsResults = lsResults & lnTemp & "."
anNewIP = anNewIP - (lnTemp * (&H100 ^ lnIndex))
Next
lsResults = Left(lsResults, Len(lsResults) - &H01)
CStringIP = lsResults
End function
'────────────────────────────────
' 轉(zhuǎn)換一個IP到數(shù)值
Public Function CLongIP(ByVal asNewIP)
Dim lnResults
Dim lnIndex
Dim lnIpAry
lnIpAry = Split(asNewIP, ".", &H04)
For lnIndex = &H00 To &H03
if Not lnIndex = &H03 Then
lnIpAry(lnIndex) = lnIpAry(lnIndex) * (&H100 ^ (&H03 - lnIndex))
End if
lnResults = lnResults + lnIpAry(lnIndex)
Next
CLongIP = lnResults
End function
'────────────────────────────────
' 取Client IP
Public Function GetClientIP()
dim uIpAddr
' 本函數(shù)參考webcn.Net/AspHouse 文獻<取真實的客戶IP>
uIpAddr = Request.ServerVariables("HTTP_X_FORWARDED_FOR")
If uIpAddr = "" Then uIpAddr = Request.ServerVariables("REMOTE_ADDR")
GetClientIP = uIpAddr
uIpAddr = ""
End function
'────────────────────────────────
' 讀取IP所在地的信息
Public function GetIpAddrInfo()
Dim tmpIpAddr
Dim IpAddrVal
Dim ic,charSpace
Dim tmpSQL
charSpace = ""
IpAddrVal = IpAddress
If Not Valid_IP(IpAddrVal) Then
GetIpAddrInfo =NULL
Exit Function
End If
'將IP字符串劈開成數(shù)組好進行處理
tmpIpAddr = Split(IpAddrVal,".",-1,1)
For ic = &H00 To Ubound(tmpIpAddr)
'補位操作,保證每間隔滿足3個字符
Select Case Len(tmpIpAddr(ic))
Case &H01 :charSpace = "00"
Case &H02 :charSpace = "0"
Case Else :charSpace = ""
End Select
tmpIpAddr(ic) = charSpace & tmpIpAddr(ic)
Next
IpAddrVal = tmpIpAddr(&H00) & "." & tmpIpAddr(&H01) & "." & tmpIpAddr(&H02) & "." & tmpIpAddr(&H03)
'以下為查詢,IP地址庫基于null追捕》的IP數(shù)據(jù)庫,感謝"馮志宏"先生的貢獻
'庫結(jié)構(gòu)如下:
'CREATE TABLE [dbo].[wry] (
' [STARTIP] [nvarchar] (17) COLLATE Chinese_PRC_CI_AS NULL , --起始IP段
' [ENDIP] [nvarchar] (17) COLLATE Chinese_PRC_CI_AS NULL , --終止IP段
' [COUNTRY] [nvarchar] (16) COLLATE Chinese_PRC_CI_AS NULL , --國家或者地區(qū)
' [LOCAL] [nvarchar] (54) COLLATE Chinese_PRC_CI_AS NULL , --本地地址
' [THANK] [nvarchar] (23) COLLATE Chinese_PRC_CI_AS NULL --感謝修正IP地址用戶姓名
') ON [PRIMARY]
'經(jīng)過分析庫的數(shù)據(jù)存放結(jié)構(gòu),總結(jié)出準確的查詢方法,具體看下面的查詢過程
tmpSQL = "select * from wry where (startIP<='" & IpAddrVal & "') and (ENDIP>='" & IpAddrVal & "') " & _
" and left(startIP," & Len(tmpIpAddr(&H00)) & ") = '" & tmpIpAddr(&H00) & "'" & _
" and left(endip," & Len(tmpIpAddr(&H00)) & ")='" & tmpIpAddr(&H00) & "'"
charSpace = GetDbIpInfo(tmpSQL)
If Len(charSpace)=&H00 Then
GetIpAddrInfo = NULL
Else
GetIpAddrInfo = charSpace
End If
charSpace = Null
tmpSQL = Null
end function
相關文章
asp連接SQL和Access數(shù)據(jù)代碼(asp里的隨機函數(shù))
asp連接SQL和Access數(shù)據(jù)代碼,asp里的隨機函數(shù),需要的朋友可以參考下2012-09-09asp下實現(xiàn)對HTML代碼進行轉(zhuǎn)換的函數(shù)
asp下實現(xiàn)對HTML代碼進行轉(zhuǎn)換的函數(shù)...2007-08-08循環(huán)取值Request.QueryString的用法
2008-01-01asp+Access通用的自動替換數(shù)據(jù)庫中的字符串
幾年前寫的一個腳本,可以自動進行整庫的數(shù)據(jù)替換。2008-06-06asp下實現(xiàn) 重新排序數(shù)字數(shù)組的代碼
asp下實現(xiàn) 重新排序數(shù)字數(shù)組的代碼...2007-08-08