国产无遮挡裸体免费直播视频,久久精品国产蜜臀av,动漫在线视频一区二区,欧亚日韩一区二区三区,久艹在线 免费视频,国产精品美女网站免费,正在播放 97超级视频在线观看,斗破苍穹年番在线观看免费,51最新乱码中文字幕

ASP常用函數(shù)收藏亂七八糟未整理版

 更新時(shí)間:2007年02月07日 00:00:00   作者:  
<%
'*******************************************************************
'取得IP地址
'*******************************************************************

Function Userip()
    Dim GetClientIP
    '如果客戶端用了代理服務(wù)器,則應(yīng)該用ServerVariables("HTTP_X_FORWARDED_FOR")方法
    GetClientIP = Request.ServerVariables("HTTP_X_FORWARDED_FOR")
    If GetClientIP = "" or IsNull(GetClientIP) or IsEmpty(GetClientIP) Then
        '如果客戶端沒用代理,應(yīng)該用Request.ServerVariables("REMOTE_ADDR")方法
        GetClientIP = Request.ServerVariables("REMOTE_ADDR")
    End If
    Userip = GetClientIP
End Function

'*******************************************************************
'轉(zhuǎn)換IP地址
'*******************************************************************

Function cip(sip)
    tip = CStr(sip)
    sip1 = Left(tip, CInt(InStr(tip, ".") -1))
    tip = Mid(tip, CInt(InStr(tip, ".") + 1))
    sip2 = Left(tip, CInt(InStr(tip, ".") -1))
    tip = Mid(tip, CInt(InStr(tip, ".") + 1))
    sip3 = Left(tip, CInt(InStr(tip, ".") -1))
    sip4 = Mid(tip, CInt(InStr(tip, ".") + 1))
    cip = CInt(sip1) * 256 * 256 * 256 + CInt(sip2) * 256 * 256 + CInt(sip3) * 256 + CInt(sip4)
End Function

'*******************************************************************
' 彈出對(duì)話框
'*******************************************************************

Sub alert(message)
    message = Replace(message, "'", "\'")
    Response.Write ("<script>alert('" & message & "')</script>")
End Sub

'*******************************************************************
' 返回上一頁(yè),一般用在判斷信息提交是否完全之后
'*******************************************************************

Sub GoBack()
    Response.Write ("<script>history.go(-1)</script>")
End Sub

'*******************************************************************
' 重定向另外的連接
'*******************************************************************

Sub Go(url)
    Response.Write ("<script>location.href('" & url & "')</script>")
End Sub

'*******************************************************************
' 我比較喜歡將以上三個(gè)結(jié)合起來(lái)使用
'*******************************************************************

Function Alert(message, gourl)
    message = Replace(message, "'", "\'")
    If gourl = "-1" Then
        Response.Write ("<script language=javascript>alert('" & message & "');history.go(-1)</script>")
    Else
        Response.Write ("<script language=javascript>alert('" & message & "');location='" & gourl &"'</script>")
    End If
    Response.End()
End Function

'*******************************************************************
' 指定秒數(shù)重定向另外的連接
'*******************************************************************

Sub GoPage(url, s)
    s = s * 1000
    Response.Write "<SCRIPT LANGUAGE=JavaScript>"
    Response.Write "window.setTimeout("&Chr(34)&"window.navigate('"&url&"')"&Chr(34)&","&s&")"
    Response.Write "</script>"
End Sub

'*******************************************************************
' 判斷數(shù)字是否整形
'*******************************************************************

Function isInteger(para)
    On Error Resume Next
    Dim Str
    Dim l, i
    If IsNull(para) Then
        isInteger = False
        Exit Function
    End If
    Str = CStr(para)
    If Trim(Str) = "" Then
        isInteger = False
        Exit Function
    End If
    l = Len(Str)
    For i = 1 To l
        If Mid(Str, i, 1)>"9" or Mid(Str, i, 1)<"0" Then
            isInteger = False
            Exit Function
        End If
    Next
    isInteger = True
    If Err.Number<>0 Then Err.Clear
End Function

'*******************************************************************
' 獲得文件擴(kuò)展名
'*******************************************************************

Function GetExtend(filename)
    Dim tmp
    If filename<>"" Then
        tmp = Mid(filename, instrrev(filename, ".") + 1, Len(filename) - instrrev(filename, "."))
        tmp = LCase(tmp)
        If InStr(1, tmp, "asp")>0 or InStr(1, tmp, "php")>0 or InStr(1, tmp, "php3")>0 or InStr(1, tmp, "aspx")>0 Then
            getextend = "txt"
        Else
            getextend = tmp
        End If
    Else
        getextend = ""
    End If
End Function

' *----------------------------------------------------------------------------
' * 函數(shù):CheckIn
' * 描述:檢測(cè)參數(shù)是否有SQL危險(xiǎn)字符
' * 參數(shù):str要檢測(cè)的數(shù)據(jù)
' * 返回:FALSE:安全 TRUE:不安全
' * 作者:
' * 日期:
' *----------------------------------------------------------------------------

Function CheckIn(Str)
    If InStr(1, Str, Chr(39))>0 or InStr(1, Str, Chr(34))>0 or InStr(1, Str, Chr(59))>0 Then
        CheckIn = True
    Else
        CheckIn = False
    End If
End Function

' *----------------------------------------------------------------------------
' * 函數(shù):HTMLEncode
' * 描述:過(guò)濾HTML代碼
' * 參數(shù):--
' * 返回:--
' * 作者:
' * 日期:
' *----------------------------------------------------------------------------

Function HTMLEncode(fString)
    If Not IsNull(fString) Then
        fString = Replace(fString, ">", ">")
        fString = Replace(fString, "<", "<")

        fString = Replace(fString, Chr(32), " ")
        fString = Replace(fString, Chr(9), " ")
        fString = Replace(fString, Chr(34), """)
        fString = Replace(fString, Chr(39), "'")
        fString = Replace(fString, Chr(13), "")
        fString = Replace(fString, Chr(10) & Chr(10), "</P><P> ")
        fString = Replace(fString, Chr(10), "<BR> ")

        HTMLEncode = fString
    End If
End Function

' *----------------------------------------------------------------------------
' * 函數(shù):HTMLcode
' * 描述:過(guò)濾表單字符
' * 參數(shù):--
' * 返回:--
' * 作者:
' * 日期:
' *----------------------------------------------------------------------------

Function HTMLcode(fString)
    If Not IsNull(fString) Then
        fString = Replace(fString, Chr(13), "")
        fString = Replace(fString, Chr(10) & Chr(10), "</P><P>")
        fString = Replace(fString, Chr(34), "")
        fString = Replace(fString, Chr(10), "<BR>")
        HTMLcode = fString
    End If
End Function

%>


<%
1.檢查是否有效郵件地址

Function CheckEmail(strEmail)
    Dim re
    Set re = New RegExp
    re.Pattern = "^[w-.]{1,}@([da-zA-Z-]{1,}.){1,}[da-zA-Z-]{2,3}$"
    re.IgnoreCase = True
    CheckEmail = re.Test(strEmail)
End Function

2.測(cè)試變量是否為空值,空值的含義包括:變量不存在 / 為空,對(duì)象為Nothing,0,空數(shù)組,字符串為空

Function IsBlank(ByRef Var)
    IsBlank = False
    Select Case True
        Case IsObject(Var)
            If Var Is Nothing Then IsBlank = True
        Case IsEmpty(Var), IsNull(Var)
            IsBlank = True
        Case IsArray(Var)
            If UBound(Var) = 0 Then IsBlank = True
        Case IsNumeric(Var)
            If (Var = 0) Then IsBlank = True
        Case Else
            If Trim(Var) = "" Then IsBlank = True
    End Select
End Function

3.得到瀏覽器目前的URL

Function GetCurURL()
    If Request.ServerVariables("HTTPS") = "on" Then
        GetCurrentURL = "https://"
    Else
        GetCurrentURL = "http://"
    End If
    GetCurURL = GetCurURL & Request.ServerVariables("SERVER_NAME")
    If (Request.ServerVariables("SERVER_PORT") <> 80) Then GetCurURL = GetCurURL & ":" & Request.ServerVariables("SERVER_PORT")
    GetCurURL = GetCurURL & Request.ServerVariables("URL")
    If (Request.QueryString <> "") Then GetCurURL = GetCurURL & "?" & Request.QueryString
End Function

4.MD5加密函數(shù)
Private Const BITS_TO_A_BYTE = 8
Private Const BYTES_TO_A_WORD = 4
Private Const BITS_TO_A_WORD = 32

Private m_lOnBits(30)
Private m_l2Power(30)

m_lOnBits(0) = CLng(1)
m_lOnBits(1) = CLng(3)
m_lOnBits(2) = CLng(7)
m_lOnBits(3) = CLng(15)
m_lOnBits(4) = CLng(31)
m_lOnBits(5) = CLng(63)
m_lOnBits(6) = CLng(127)
m_lOnBits(7) = CLng(255)
m_lOnBits(8) = CLng(511)
m_lOnBits(9) = CLng(1023)
m_lOnBits(10) = CLng(2047)
m_lOnBits(11) = CLng(4095)
m_lOnBits(12) = CLng(8191)
m_lOnBits(13) = CLng(16383)
m_lOnBits(14) = CLng(32767)
m_lOnBits(15) = CLng(65535)
m_lOnBits(16) = CLng(131071)
m_lOnBits(17) = CLng(262143)
m_lOnBits(18) = CLng(524287)
m_lOnBits(19) = CLng(1048575)
m_lOnBits(20) = CLng(2097151)
m_lOnBits(21) = CLng(4194303)
m_lOnBits(22) = CLng(8388607)
m_lOnBits(23) = CLng(16777215)
m_lOnBits(24) = CLng(33554431)
m_lOnBits(25) = CLng(67108863)
m_lOnBits(26) = CLng(134217727)
m_lOnBits(27) = CLng(268435455)
m_lOnBits(28) = CLng(536870911)
m_lOnBits(29) = CLng(1073741823)
m_lOnBits(30) = CLng(2147483647)

m_l2Power(0) = CLng(1)
m_l2Power(1) = CLng(2)
m_l2Power(2) = CLng(4)
m_l2Power(3) = CLng(8)
m_l2Power(4) = CLng(16)
m_l2Power(5) = CLng(32)
m_l2Power(6) = CLng(64)
m_l2Power(7) = CLng(128)
m_l2Power(8) = CLng(256)
m_l2Power(9) = CLng(512)
m_l2Power(10) = CLng(1024)
m_l2Power(11) = CLng(2048)
m_l2Power(12) = CLng(4096)
m_l2Power(13) = CLng(8192)
m_l2Power(14) = CLng(16384)
m_l2Power(15) = CLng(32768)
m_l2Power(16) = CLng(65536)
m_l2Power(17) = CLng(131072)
m_l2Power(18) = CLng(262144)
m_l2Power(19) = CLng(524288)
m_l2Power(20) = CLng(1048576)
m_l2Power(21) = CLng(2097152)
m_l2Power(22) = CLng(4194304)
m_l2Power(23) = CLng(8388608)
m_l2Power(24) = CLng(16777216)
m_l2Power(25) = CLng(33554432)
m_l2Power(26) = CLng(67108864)
m_l2Power(27) = CLng(134217728)
m_l2Power(28) = CLng(268435456)
m_l2Power(29) = CLng(536870912)
m_l2Power(30) = CLng(1073741824)

Private Function LShift(lValue, iShiftBits)
    If iShiftBits = 0 Then
        LShift = lValue
        Exit Function
    ElseIf iShiftBits = 31 Then
        If lValue And 1 Then
            LShift = &H80000000
        Else
            LShift = 0
        End If
        Exit Function
    ElseIf iShiftBits < 0 or iShiftBits > 31 Then
        Err.Raise 6
    End If

    If (lValue And m_l2Power(31 - iShiftBits)) Then
        LShift = ((lValue And m_lOnBits(31 - (iShiftBits + 1))) * m_l2Power(iShiftBits)) or &H80000000
    Else
        LShift = ((lValue And m_lOnBits(31 - iShiftBits)) * m_l2Power(iShiftBits))
    End If
End Function

Private Function RShift(lValue, iShiftBits)
    If iShiftBits = 0 Then
        RShift = lValue
        Exit Function
    ElseIf iShiftBits = 31 Then
        If lValue And &H80000000 Then
            RShift = 1
        Else
            RShift = 0
        End If
        Exit Function
    ElseIf iShiftBits < 0 or iShiftBits > 31 Then
        Err.Raise 6
    End If

    RShift = (lValue And &H7FFFFFFE) m_l2Power(iShiftBits)

    If (lValue And &H80000000) Then
        RShift = (RShift or (&H40000000 m_l2Power(iShiftBits - 1)))
    End If
End Function

Private Function RotateLeft(lValue, iShiftBits)
    RotateLeft = LShift(lValue, iShiftBits) or RShift(lValue, (32 - iShiftBits))
End Function

Private Function AddUnsigned(lX, lY)
    Dim lX4
    Dim lY4
    Dim lX8
    Dim lY8
    Dim lResult

    lX8 = lX And &H80000000
    lY8 = lY And &H80000000
    lX4 = lX And &H40000000
    lY4 = lY And &H40000000

    lResult = (lX And &H3FFFFFFF) + (lY And &H3FFFFFFF)

    If lX4 And lY4 Then
        lResult = lResult Xor &H80000000 Xor lX8 Xor lY8
    ElseIf lX4 or lY4 Then
        If lResult And &H40000000 Then
            lResult = lResult Xor &HC0000000 Xor lX8 Xor lY8
        Else
            lResult = lResult Xor &H40000000 Xor lX8 Xor lY8
        End If
    Else
        lResult = lResult Xor lX8 Xor lY8
    End If

    AddUnsigned = lResult
End Function

Private Function F(x, y, z)
    F = (x And y) or ((Not x) And z)
End Function

Private Function G(x, y, z)
    G = (x And z) or (y And (Not z))
End Function

Private Function H(x, y, z)
    H = (x Xor y Xor z)
End Function

Private Function I(x, y, z)
    I = (y Xor (x or (Not z)))
End Function

Private Sub FF(a, b, c, d, x, s, ac)
    a = AddUnsigned(a, AddUnsigned(AddUnsigned(F(b, c, d), x), ac))
    a = RotateLeft(a, s)
    a = AddUnsigned(a, b)
End Sub

Private Sub GG(a, b, c, d, x, s, ac)
    a = AddUnsigned(a, AddUnsigned(AddUnsigned(G(b, c, d), x), ac))
    a = RotateLeft(a, s)
    a = AddUnsigned(a, b)
End Sub

Private Sub HH(a, b, c, d, x, s, ac)
    a = AddUnsigned(a, AddUnsigned(AddUnsigned(H(b, c, d), x), ac))
    a = RotateLeft(a, s)
    a = AddUnsigned(a, b)
End Sub

Private Sub II(a, b, c, d, x, s, ac)
    a = AddUnsigned(a, AddUnsigned(AddUnsigned(I(b, c, d), x), ac))
    a = RotateLeft(a, s)
    a = AddUnsigned(a, b)
End Sub

Private Function ConvertToWordArray(sMessage)
    Dim lMessageLength
    Dim lNumberOfWords
    Dim lWordArray()
    Dim lBytePosition
    Dim lByteCount
    Dim lWordCount

    Const MODULUS_BITS = 512
    Const CONGRUENT_BITS = 448

    lMessageLength = Len(sMessage)

    lNumberOfWords = (((lMessageLength + ((MODULUS_BITS - CONGRUENT_BITS) BITS_TO_A_BYTE)) (MODULUS_BITS BITS_TO_A_BYTE)) + 1) * (MODULUS_BITS BITS_TO_A_WORD)
    ReDim lWordArray(lNumberOfWords - 1)

    lBytePosition = 0
    lByteCount = 0
    Do Until lByteCount >= lMessageLength
        lWordCount = lByteCount BYTES_TO_A_WORD
        lBytePosition = (lByteCount Mod BYTES_TO_A_WORD) * BITS_TO_A_BYTE
        lWordArray(lWordCount) = lWordArray(lWordCount) or LShift(Asc(Mid(sMessage, lByteCount + 1, 1)), lBytePosition)
        lByteCount = lByteCount + 1
    Loop

    lWordCount = lByteCount BYTES_TO_A_WORD
    lBytePosition = (lByteCount Mod BYTES_TO_A_WORD) * BITS_TO_A_BYTE

    lWordArray(lWordCount) = lWordArray(lWordCount) or LShift(&H80, lBytePosition)

    lWordArray(lNumberOfWords - 2) = LShift(lMessageLength, 3)
    lWordArray(lNumberOfWords - 1) = RShift(lMessageLength, 29)

    ConvertToWordArray = lWordArray
End Function

Private Function WordToHex(lValue)
    Dim lByte
    Dim lCount

    For lCount = 0 To 3
        lByte = RShift(lValue, lCount * BITS_TO_A_BYTE) And m_lOnBits(BITS_TO_A_BYTE - 1)
        WordToHex = WordToHex & Right("0" & Hex(lByte), 2)
    Next
End Function

Public Function MD5(sMessage)
    Dim x
    Dim k
    Dim AA
    Dim BB
    Dim CC
    Dim DD
    Dim a
    Dim b
    Dim c
    Dim d

    Const S11 = 7
    Const S12 = 12
    Const S13 = 17
    Const S14 = 22
    Const S21 = 5
    Const S22 = 9
    Const S23 = 14
    Const S24 = 20
    Const S31 = 4
    Const S32 = 11
    Const S33 = 16
    Const S34 = 23
    Const S41 = 6
    Const S42 = 10
    Const S43 = 15
    Const S44 = 21

    x = ConvertToWordArray(sMessage)

    a = &H67452301
    b = &HEFCDAB89
    c = &H98BADCFE
    d = &H10325476

    For k = 0 To UBound(x) Step 16
        AA = a
        BB = b
        CC = c
        DD = d

        FF a, b, c, d, x(k + 0), S11, &HD76AA478
        FF d, a, b, c, x(k + 1), S12, &HE8C7B756
        FF c, d, a, b, x(k + 2), S13, &H242070DB
        FF b, c, d, a, x(k + 3), S14, &HC1BDCEEE
        FF a, b, c, d, x(k + 4), S11, &HF57C0FAF
        FF d, a, b, c, x(k + 5), S12, &H4787C62A
        FF c, d, a, b, x(k + 6), S13, &HA8304613
        FF b, c, d, a, x(k + 7), S14, &HFD469501
        FF a, b, c, d, x(k + 8), S11, &H698098D8
        FF d, a, b, c, x(k + 9), S12, &H8B44F7AF
        FF c, d, a, b, x(k + 10), S13, &HFFFF5BB1
        FF b, c, d, a, x(k + 11), S14, &H895CD7BE
        FF a, b, c, d, x(k + 12), S11, &H6B901122
        FF d, a, b, c, x(k + 13), S12, &HFD987193
        FF c, d, a, b, x(k + 14), S13, &HA679438E
        FF b, c, d, a, x(k + 15), S14, &H49B40821

        GG a, b, c, d, x(k + 1), S21, &HF61E2562
        GG d, a, b, c, x(k + 6), S22, &HC040B340
        GG c, d, a, b, x(k + 11), S23, &H265E5A51
        GG b, c, d, a, x(k + 0), S24, &HE9B6C7AA
        GG a, b, c, d, x(k + 5), S21, &HD62F105D
        GG d, a, b, c, x(k + 10), S22, &H2441453
        GG c, d, a, b, x(k + 15), S23, &HD8A1E681
        GG b, c, d, a, x(k + 4), S24, &HE7D3FBC8
        GG a, b, c, d, x(k + 9), S21, &H21E1CDE6
        GG d, a, b, c, x(k + 14), S22, &HC33707D6
        GG c, d, a, b, x(k + 3), S23, &HF4D50D87
        GG b, c, d, a, x(k + 8), S24, &H455A14ED
        GG a, b, c, d, x(k + 13), S21, &HA9E3E905
        GG d, a, b, c, x(k + 2), S22, &HFCEFA3F8
        GG c, d, a, b, x(k + 7), S23, &H676F02D9
        GG b, c, d, a, x(k + 12), S24, &H8D2A4C8A

        HH a, b, c, d, x(k + 5), S31, &HFFFA3942
        HH d, a, b, c, x(k + 8), S32, &H8771F681
        HH c, d, a, b, x(k + 11), S33, &H6D9D6122
        HH b, c, d, a, x(k + 14), S34, &HFDE5380C
        HH a, b, c, d, x(k + 1), S31, &HA4BEEA44
        HH d, a, b, c, x(k + 4), S32, &H4BDECFA9
        HH c, d, a, b, x(k + 7), S33, &HF6BB4B60
        HH b, c, d, a, x(k + 10), S34, &HBEBFBC70
        HH a, b, c, d, x(k + 13), S31, &H289B7EC6
        HH d, a, b, c, x(k + 0), S32, &HEAA127FA
        HH c, d, a, b, x(k + 3), S33, &HD4EF3085
        HH b, c, d, a, x(k + 6), S34, &H4881D05
        HH a, b, c, d, x(k + 9), S31, &HD9D4D039
        HH d, a, b, c, x(k + 12), S32, &HE6DB99E5
        HH c, d, a, b, x(k + 15), S33, &H1FA27CF8
        HH b, c, d, a, x(k + 2), S34, &HC4AC5665

        II a, b, c, d, x(k + 0), S41, &HF4292244
        II d, a, b, c, x(k + 7), S42, &H432AFF97
        II c, d, a, b, x(k + 14), S43, &HAB9423A7
        II b, c, d, a, x(k + 5), S44, &HFC93A039
        II a, b, c, d, x(k + 12), S41, &H655B59C3
        II d, a, b, c, x(k + 3), S42, &H8F0CCC92
        II c, d, a, b, x(k + 10), S43, &HFFEFF47D
        II b, c, d, a, x(k + 1), S44, &H85845DD1
        II a, b, c, d, x(k + 8), S41, &H6FA87E4F
        II d, a, b, c, x(k + 15), S42, &HFE2CE6E0
        II c, d, a, b, x(k + 6), S43, &HA3014314
        II b, c, d, a, x(k + 13), S44, &H4E0811A1
        II a, b, c, d, x(k + 4), S41, &HF7537E82
        II d, a, b, c, x(k + 11), S42, &HBD3AF235
        II c, d, a, b, x(k + 2), S43, &H2AD7D2BB
        II b, c, d, a, x(k + 9), S44, &HEB86D391

        a = AddUnsigned(a, AA)
        b = AddUnsigned(b, BB)
        c = AddUnsigned(c, CC)
        d = AddUnsigned(d, DD)
    Next

    MD5 = LCase(WordToHex(a) & WordToHex(b) & WordToHex(c) & WordToHex(d))
End Function

5.SHA256 加密,256位的加密哦!安全性更高!
Private m_lOnBits(30)
Private m_l2Power(30)
Private K(63)

Private Const BITS_TO_A_BYTE = 8
Private Const BYTES_TO_A_WORD = 4
Private Const BITS_TO_A_WORD = 32

m_lOnBits(0) = CLng(1)
m_lOnBits(1) = CLng(3)
m_lOnBits(2) = CLng(7)
m_lOnBits(3) = CLng(15)
m_lOnBits(4) = CLng(31)
m_lOnBits(5) = CLng(63)
m_lOnBits(6) = CLng(127)
m_lOnBits(7) = CLng(255)
m_lOnBits(8) = CLng(511)
m_lOnBits(9) = CLng(1023)
m_lOnBits(10) = CLng(2047)
m_lOnBits(11) = CLng(4095)
m_lOnBits(12) = CLng(8191)
m_lOnBits(13) = CLng(16383)
m_lOnBits(14) = CLng(32767)
m_lOnBits(15) = CLng(65535)
m_lOnBits(16) = CLng(131071)
m_lOnBits(17) = CLng(262143)
m_lOnBits(18) = CLng(524287)
m_lOnBits(19) = CLng(1048575)
m_lOnBits(20) = CLng(2097151)
m_lOnBits(21) = CLng(4194303)
m_lOnBits(22) = CLng(8388607)
m_lOnBits(23) = CLng(16777215)
m_lOnBits(24) = CLng(33554431)
m_lOnBits(25) = CLng(67108863)
m_lOnBits(26) = CLng(134217727)
m_lOnBits(27) = CLng(268435455)
m_lOnBits(28) = CLng(536870911)
m_lOnBits(29) = CLng(1073741823)
m_lOnBits(30) = CLng(2147483647)

m_l2Power(0) = CLng(1)
m_l2Power(1) = CLng(2)
m_l2Power(2) = CLng(4)
m_l2Power(3) = CLng(8)
m_l2Power(4) = CLng(16)
m_l2Power(5) = CLng(32)
m_l2Power(6) = CLng(64)
m_l2Power(7) = CLng(128)
m_l2Power(8) = CLng(256)
m_l2Power(9) = CLng(512)
m_l2Power(10) = CLng(1024)
m_l2Power(11) = CLng(2048)
m_l2Power(12) = CLng(4096)
m_l2Power(13) = CLng(8192)
m_l2Power(14) = CLng(16384)
m_l2Power(15) = CLng(32768)
m_l2Power(16) = CLng(65536)
m_l2Power(17) = CLng(131072)
m_l2Power(18) = CLng(262144)
m_l2Power(19) = CLng(524288)
m_l2Power(20) = CLng(1048576)
m_l2Power(21) = CLng(2097152)
m_l2Power(22) = CLng(4194304)
m_l2Power(23) = CLng(8388608)
m_l2Power(24) = CLng(16777216)
m_l2Power(25) = CLng(33554432)
m_l2Power(26) = CLng(67108864)
m_l2Power(27) = CLng(134217728)
m_l2Power(28) = CLng(268435456)
m_l2Power(29) = CLng(536870912)
m_l2Power(30) = CLng(1073741824)

K(0) = &H428A2F98
K(1) = &H71374491
K(2) = &HB5C0FBCF
K(3) = &HE9B5DBA5
K(4) = &H3956C25B
K(5) = &H59F111F1
K(6) = &H923F82A4
K(7) = &HAB1C5ED5
K(8) = &HD807AA98
K(9) = &H12835B01
K(10) = &H243185BE
K(11) = &H550C7DC3
K(12) = &H72BE5D74
K(13) = &H80DEB1FE
K(14) = &H9BDC06A7
K(15) = &HC19BF174
K(16) = &HE49B69C1
K(17) = &HEFBE4786
K(18) = &HFC19DC6
K(19) = &H240CA1CC
K(20) = &H2DE92C6F
K(21) = &H4A7484AA
K(22) = &H5CB0A9DC
K(23) = &H76F988DA
K(24) = &H983E5152
K(25) = &HA831C66D
K(26) = &HB00327C8
K(27) = &HBF597FC7
K(28) = &HC6E00BF3
K(29) = &HD5A79147
K(30) = &H6CA6351
K(31) = &H14292967
K(32) = &H27B70A85
K(33) = &H2E1B2138
K(34) = &H4D2C6DFC
K(35) = &H53380D13
K(36) = &H650A7354
K(37) = &H766A0ABB
K(38) = &H81C2C92E
K(39) = &H92722C85
K(40) = &HA2BFE8A1
K(41) = &HA81A664B
K(42) = &HC24B8B70
K(43) = &HC76C51A3
K(44) = &HD192E819
K(45) = &HD6990624
K(46) = &HF40E3585
K(47) = &H106AA070
K(48) = &H19A4C116
K(49) = &H1E376C08
K(50) = &H2748774C
K(51) = &H34B0BCB5
K(52) = &H391C0CB3
K(53) = &H4ED8AA4A
K(54) = &H5B9CCA4F
K(55) = &H682E6FF3
K(56) = &H748F82EE
K(57) = &H78A5636F
K(58) = &H84C87814
K(59) = &H8CC70208
K(60) = &H90BEFFFA
K(61) = &HA4506CEB
K(62) = &HBEF9A3F7
K(63) = &HC67178F2

Private Function LShift(lValue, iShiftBits)
    If iShiftBits = 0 Then
        LShift = lValue
        Exit Function
    ElseIf iShiftBits = 31 Then
        If lValue And 1 Then
            LShift = &H80000000
        Else
            LShift = 0
        End If
        Exit Function
    ElseIf iShiftBits < 0 or iShiftBits > 31 Then
        Err.Raise 6
    End If

    If (lValue And m_l2Power(31 - iShiftBits)) Then
        LShift = ((lValue And m_lOnBits(31 - (iShiftBits + 1))) * m_l2Power(iShiftBits)) or &H80000000
    Else
        LShift = ((lValue And m_lOnBits(31 - iShiftBits)) * m_l2Power(iShiftBits))
    End If
End Function

Private Function RShift(lValue, iShiftBits)
    If iShiftBits = 0 Then
        RShift = lValue
        Exit Function
    ElseIf iShiftBits = 31 Then
        If lValue And &H80000000 Then
            RShift = 1
        Else
            RShift = 0
        End If
        Exit Function
    ElseIf iShiftBits < 0 or iShiftBits > 31 Then
        Err.Raise 6
    End If

    RShift = (lValue And &H7FFFFFFE) m_l2Power(iShiftBits)

    If (lValue And &H80000000) Then
        RShift = (RShift or (&H40000000 m_l2Power(iShiftBits - 1)))
    End If
End Function

Private Function AddUnsigned(lX, lY)
    Dim lX4
    Dim lY4
    Dim lX8
    Dim lY8
    Dim lResult

    lX8 = lX And &H80000000
    lY8 = lY And &H80000000
    lX4 = lX And &H40000000
    lY4 = lY And &H40000000

    lResult = (lX And &H3FFFFFFF) + (lY And &H3FFFFFFF)

    If lX4 And lY4 Then
        lResult = lResult Xor &H80000000 Xor lX8 Xor lY8
    ElseIf lX4 or lY4 Then
        If lResult And &H40000000 Then
            lResult = lResult Xor &HC0000000 Xor lX8 Xor lY8
        Else
            lResult = lResult Xor &H40000000 Xor lX8 Xor lY8
        End If
    Else
        lResult = lResult Xor lX8 Xor lY8
    End If

    AddUnsigned = lResult
End Function

Private Function Ch(x, y, z)
    Ch = ((x And y) Xor ((Not x) And z))
End Function

Private Function Maj(x, y, z)
    Maj = ((x And y) Xor (x And z) Xor (y And z))
End Function

Private Function S(x, n)
    S = (RShift(x, (n And m_lOnBits(4))) or LShift(x, (32 - (n And m_lOnBits(4)))))
End Function

Private Function R(x, n)
    R = RShift(x, CInt(n And m_lOnBits(4)))
End Function

Private Function Sigma0(x)
    Sigma0 = (S(x, 2) Xor S(x, 13) Xor S(x, 22))
End Function

Private Function Sigma1(x)
    Sigma1 = (S(x, 6) Xor S(x, 11) Xor S(x, 25))
End Function

Private Function Gamma0(x)
    Gamma0 = (S(x, 7) Xor S(x, 18) Xor R(x, 3))
End Function

Private Function Gamma1(x)
    Gamma1 = (S(x, 17) Xor S(x, 19) Xor R(x, 10))
End Function

Private Function ConvertToWordArray(sMessage)
    Dim lMessageLength
    Dim lNumberOfWords
    Dim lWordArray()
    Dim lBytePosition
    Dim lByteCount
    Dim lWordCount
    Dim lByte

    Const MODULUS_BITS = 512
    Const CONGRUENT_BITS = 448

    lMessageLength = Len(sMessage)

    lNumberOfWords = (((lMessageLength + ((MODULUS_BITS - CONGRUENT_BITS) BITS_TO_A_BYTE)) (MODULUS_BITS BITS_TO_A_BYTE)) + 1) * (MODULUS_BITS BITS_TO_A_WORD)
    ReDim lWordArray(lNumberOfWords - 1)

    lBytePosition = 0
    lByteCount = 0
    Do Until lByteCount >= lMessageLength
        lWordCount = lByteCount BYTES_TO_A_WORD

        lBytePosition = (3 - (lByteCount Mod BYTES_TO_A_WORD)) * BITS_TO_A_BYTE

        lByte = AscB(Mid(sMessage, lByteCount + 1, 1))

        lWordArray(lWordCount) = lWordArray(lWordCount) or LShift(lByte, lBytePosition)
        lByteCount = lByteCount + 1
    Loop

    lWordCount = lByteCount BYTES_TO_A_WORD
    lBytePosition = (3 - (lByteCount Mod BYTES_TO_A_WORD)) * BITS_TO_A_BYTE

    lWordArray(lWordCount) = lWordArray(lWordCount) or LShift(&H80, lBytePosition)

    lWordArray(lNumberOfWords - 1) = LShift(lMessageLength, 3)
    lWordArray(lNumberOfWords - 2) = RShift(lMessageLength, 29)

    ConvertToWordArray = lWordArray
End Function

Public Function SHA256(sMessage)
    Dim HASH(7)
    Dim M
    Dim W(63)
    Dim a
    Dim b
    Dim c
    Dim d
    Dim e
    Dim f
    Dim g
    Dim h
    Dim i
    Dim j
    Dim T1
    Dim T2

    HASH(0) = &H6A09E667
    HASH(1) = &HBB67AE85
    HASH(2) = &H3C6EF372
    HASH(3) = &HA54FF53A
    HASH(4) = &H510E527F
    HASH(5) = &H9B05688C
    HASH(6) = &H1F83D9AB
    HASH(7) = &H5BE0CD19

    M = ConvertToWordArray(sMessage)

    For i = 0 To UBound(M) Step 16
        a = HASH(0)
        b = HASH(1)
        c = HASH(2)
        d = HASH(3)
        e = HASH(4)
        f = HASH(5)
        g = HASH(6)
        h = HASH(7)

        For j = 0 To 63
            If j < 16 Then
                W(j) = M(j + i)
            Else
                W(j) = AddUnsigned(AddUnsigned(AddUnsigned(Gamma1(W(j - 2)), W(j - 7)), Gamma0(W(j - 15))), W(j - 16))
            End If

            T1 = AddUnsigned(AddUnsigned(AddUnsigned(AddUnsigned(h, Sigma1(e)), Ch(e, f, g)), K(j)), W(j))
            T2 = AddUnsigned(Sigma0(a), Maj(a, b, c))

            h = g
            g = f
            f = e
            e = AddUnsigned(d, T1)
            d = c
            c = b
            b = a
            a = AddUnsigned(T1, T2)
        Next

        HASH(0) = AddUnsigned(a, HASH(0))
        HASH(1) = AddUnsigned(b, HASH(1))
        HASH(2) = AddUnsigned(c, HASH(2))
        HASH(3) = AddUnsigned(d, HASH(3))
        HASH(4) = AddUnsigned(e, HASH(4))
        HASH(5) = AddUnsigned(f, HASH(5))
        HASH(6) = AddUnsigned(g, HASH(6))
        HASH(7) = AddUnsigned(h, HASH(7))
    Next

    SHA256 = LCase(Right("00000000" & Hex(HASH(0)), 8) & Right("00000000" & Hex(HASH(1)), 8) & Right("00000000" & Hex(HASH(2)), 8) & Right("00000000" & Hex(HASH(3)), 8) & Right("00000000" & Hex(HASH(4)), 8) & Right("00000000" & Hex(HASH(5)), 8) & Right("00000000" & Hex(HASH(6)), 8) & Right("00000000" & Hex(HASH(7)), 8))
End Function

6.一個(gè)If語(yǔ)句的加工,以后可以用類似于PHP或JS的 If () ? ..
...代碼了

Function IIf(Condition, ValueIfTrue, ValueIfFalse)
    If Condition Then
        IIf = ValueIfTrue
    Else
        IIf = ValueIfFalse
    End If
End Function

7.ASE加密函數(shù)
Private m_lOnBits(30)
Private m_l2Power(30)
Private m_bytOnBits(7)
Private m_byt2Power(7)

Private m_InCo(3)

Private m_fbsub(255)
Private m_rbsub(255)
Private m_ptab(255)
Private m_ltab(255)
Private m_ftable(255)
Private m_rtable(255)
Private m_rco(29)

Private m_Nk
Private m_Nb
Private m_Nr
Private m_fi(23)
Private m_ri(23)
Private m_fkey(119)
Private m_rkey(119)

m_InCo(0) = &HB
m_InCo(1) = &HD
m_InCo(2) = &H9
m_InCo(3) = &HE

m_bytOnBits(0) = 1
m_bytOnBits(1) = 3
m_bytOnBits(2) = 7
m_bytOnBits(3) = 15
m_bytOnBits(4) = 31
m_bytOnBits(5) = 63
m_bytOnBits(6) = 127
m_bytOnBits(7) = 255

m_byt2Power(0) = 1
m_byt2Power(1) = 2
m_byt2Power(2) = 4
m_byt2Power(3) = 8
m_byt2Power(4) = 16
m_byt2Power(5) = 32
m_byt2Power(6) = 64
m_byt2Power(7) = 128

m_lOnBits(0) = 1
m_lOnBits(1) = 3
m_lOnBits(2) = 7
m_lOnBits(3) = 15
m_lOnBits(4) = 31
m_lOnBits(5) = 63
m_lOnBits(6) = 127
m_lOnBits(7) = 255
m_lOnBits(8) = 511
m_lOnBits(9) = 1023
m_lOnBits(10) = 2047
m_lOnBits(11) = 4095
m_lOnBits(12) = 8191
m_lOnBits(13) = 16383
m_lOnBits(14) = 32767
m_lOnBits(15) = 65535
m_lOnBits(16) = 131071
m_lOnBits(17) = 262143
m_lOnBits(18) = 524287
m_lOnBits(19) = 1048575
m_lOnBits(20) = 2097151
m_lOnBits(21) = 4194303
m_lOnBits(22) = 8388607
m_lOnBits(23) = 16777215
m_lOnBits(24) = 33554431
m_lOnBits(25) = 67108863
m_lOnBits(26) = 134217727
m_lOnBits(27) = 268435455
m_lOnBits(28) = 536870911
m_lOnBits(29) = 1073741823
m_lOnBits(30) = 2147483647

m_l2Power(0) = 1
m_l2Power(1) = 2
m_l2Power(2) = 4
m_l2Power(3) = 8
m_l2Power(4) = 16
m_l2Power(5) = 32
m_l2Power(6) = 64
m_l2Power(7) = 128
m_l2Power(8) = 256
m_l2Power(9) = 512
m_l2Power(10) = 1024
m_l2Power(11) = 2048
m_l2Power(12) = 4096
m_l2Power(13) = 8192
m_l2Power(14) = 16384
m_l2Power(15) = 32768
m_l2Power(16) = 65536
m_l2Power(17) = 131072
m_l2Power(18) = 262144
m_l2Power(19) = 524288
m_l2Power(20) = 1048576
m_l2Power(21) = 2097152
m_l2Power(22) = 4194304
m_l2Power(23) = 8388608
m_l2Power(24) = 16777216
m_l2Power(25) = 33554432
m_l2Power(26) = 67108864
m_l2Power(27) = 134217728
m_l2Power(28) = 268435456
m_l2Power(29) = 536870912
m_l2Power(30) = 1073741824

Private Function LShift(lValue, iShiftBits)
    If iShiftBits = 0 Then
        LShift = lValue
        Exit Function
    ElseIf iShiftBits = 31 Then
        If lValue And 1 Then
            LShift = &H80000000
        Else
            LShift = 0
        End If
        Exit Function
    ElseIf iShiftBits < 0 or iShiftBits > 31 Then
        Err.Raise 6
    End If

    If (lValue And m_l2Power(31 - iShiftBits)) Then
        LShift = ((lValue And m_lOnBits(31 - (iShiftBits + 1))) * m_l2Power(iShiftBits)) or &H80000000
    Else
        LShift = ((lValue And m_lOnBits(31 - iShiftBits)) * m_l2Power(iShiftBits))
    End If
End Function

Private Function RShift(lValue, iShiftBits)
    If iShiftBits = 0 Then
        RShift = lValue
        Exit Function
    ElseIf iShiftBits = 31 Then
        If lValue And &H80000000 Then
            RShift = 1
        Else
            RShift = 0
        End If
        Exit Function
    ElseIf iShiftBits < 0 or iShiftBits > 31 Then
        Err.Raise 6
    End If

    RShift = (lValue And &H7FFFFFFE) m_l2Power(iShiftBits)

    If (lValue And &H80000000) Then
        RShift = (RShift or (&H40000000 m_l2Power(iShiftBits - 1)))
    End If
End Function

Private Function LShiftByte(bytValue, bytShiftBits)
    If bytShiftBits = 0 Then
        LShiftByte = bytValue
        Exit Function
    ElseIf bytShiftBits = 7 Then
        If bytValue And 1 Then
            LShiftByte = &H80
        Else
            LShiftByte = 0
        End If
        Exit Function
    ElseIf bytShiftBits < 0 or bytShiftBits > 7 Then
        Err.Raise 6
    End If

    LShiftByte = ((bytValue And m_bytOnBits(7 - bytShiftBits)) * m_byt2Power(bytShiftBits))
End Function

Private Function RShiftByte(bytValue, bytShiftBits)
    If bytShiftBits = 0 Then
        RShiftByte = bytValue
        Exit Function
    ElseIf bytShiftBits = 7 Then
        If bytValue And &H80 Then
            RShiftByte = 1
        Else
            RShiftByte = 0
        End If
        Exit Function
    ElseIf bytShiftBits < 0 or bytShiftBits > 7 Then
        Err.Raise 6
    End If

    RShiftByte = bytValue m_byt2Power(bytShiftBits)
End Function

Private Function RotateLeft(lValue, iShiftBits)
    RotateLeft = LShift(lValue, iShiftBits) or RShift(lValue, (32 - iShiftBits))
End Function

Private Function RotateLeftByte(bytValue, bytShiftBits)
    RotateLeftByte = LShiftByte(bytValue, bytShiftBits) or RShiftByte(bytValue, (8 - bytShiftBits))
End Function

Private Function Pack(b())
    Dim lCount
    Dim lTemp

    For lCount = 0 To 3
        lTemp = b(lCount)
        Pack = Pack or LShift(lTemp, (lCount * 8))
    Next
End Function

Private Function PackFrom(b(), k)
    Dim lCount
    Dim lTemp

    For lCount = 0 To 3
        lTemp = b(lCount + k)
        PackFrom = PackFrom or LShift(lTemp, (lCount * 8))
    Next
End Function

Private Sub Unpack(a, b())
    b(0) = a And m_lOnBits(7)
    b(1) = RShift(a, 8) And m_lOnBits(7)
    b(2) = RShift(a, 16) And m_lOnBits(7)
    b(3) = RShift(a, 24) And m_lOnBits(7)
End Sub

Private Sub UnpackFrom(a, b(), k)
    b(0 + k) = a And m_lOnBits(7)
    b(1 + k) = RShift(a, 8) And m_lOnBits(7)
    b(2 + k) = RShift(a, 16) And m_lOnBits(7)
    b(3 + k) = RShift(a, 24) And m_lOnBits(7)
End Sub

Private Function xtime(a)
    Dim b

    If (a And &H80) Then
        b = &H1B
    Else
        b = 0
    End If

    xtime = LShiftByte(a, 1)
    xtime = xtime Xor b
End Function

Private Function bmul(x, y)
    If x <> 0 And y <> 0 Then
        bmul = m_ptab((CLng(m_ltab(x)) + CLng(m_ltab(y))) Mod 255)
    Else
        bmul = 0
    End If
End Function

Private Function SubByte(a)
    Dim b(3)

    Unpack a, b
    b(0) = m_fbsub(b(0))
    b(1) = m_fbsub(b(1))
    b(2) = m_fbsub(b(2))
    b(3) = m_fbsub(b(3))

    SubByte = Pack(b)
End Function

Private Function product(x, y)
    Dim xb(3)
    Dim yb(3)

    Unpack x, xb
    Unpack y, yb
    product = bmul(xb(0), yb(0)) Xor bmul(xb(1), yb(1)) Xor bmul(xb(2), yb(2)) Xor bmul(xb(3), yb(3))
End Function

Private Function InvMixCol(x)
    Dim y
    Dim m
    Dim b(3)

    m = Pack(m_InCo)
    b(3) = product(m, x)
    m = RotateLeft(m, 24)
    b(2) = product(m, x)
    m = RotateLeft(m, 24)
    b(1) = product(m, x)
    m = RotateLeft(m, 24)
    b(0) = product(m, x)
    y = Pack(b)

    InvMixCol = y
End Function

Private Function ByteSub(x)
    Dim y
    Dim z

    z = x
    y = m_ptab(255 - m_ltab(z))
    z = y
    z = RotateLeftByte(z, 1)
    y = y Xor z
    z = RotateLeftByte(z, 1)
    y = y Xor z
    z = RotateLeftByte(z, 1)
    y = y Xor z
    z = RotateLeftByte(z, 1)
    y = y Xor z
    y = y Xor &H63

    ByteSub = y
End Function

Public Sub gentables()
    Dim i
    Dim y
    Dim b(3)
    Dim ib

    m_ltab(0) = 0
    m_ptab(0) = 1
    m_ltab(1) = 0
    m_ptab(1) = 3
    m_ltab(3) = 1

    For i = 2 To 255
        m_ptab(i) = m_ptab(i - 1) Xor xtime(m_ptab(i - 1))
        m_ltab(m_ptab(i)) = i
    Next

    m_fbsub(0) = &H63
    m_rbsub(&H63) = 0

    For i = 1 To 255
        ib = i
        y = ByteSub(ib)
        m_fbsub(i) = y
        m_rbsub(y) = i
    Next

    y = 1
    For i = 0 To 29
        m_rco(i) = y
        y = xtime(y)
    Next

    For i = 0 To 255
        y = m_fbsub(i)
        b(3) = y Xor xtime(y)
        b(2) = y
        b(1) = y
        b(0) = xtime(y)
        m_ftable(i) = Pack(b)

        y = m_rbsub(i)
        b(3) = bmul(m_InCo(0), y)
        b(2) = bmul(m_InCo(1), y)
        b(1) = bmul(m_InCo(2), y)
        b(0) = bmul(m_InCo(3), y)
        m_rtable(i) = Pack(b)
    Next
End Sub

Public Sub gkey(nb, nk, Key())
    Dim i
    Dim j
    Dim k
    Dim m
    Dim N
    Dim C1
    Dim C2
    Dim C3
    Dim CipherKey(7)

    m_Nb = nb
    m_Nk = nk

    If m_Nb >= m_Nk Then
        m_Nr = 6 + m_Nb
    Else
        m_Nr = 6 + m_Nk
    End If

    C1 = 1
    If m_Nb < 8 Then
        C2 = 2
        C3 = 3
    Else
        C2 = 3
        C3 = 4
    End If

    For j = 0 To nb - 1
        m = j * 3

        m_fi(m) = (j + C1) Mod nb
        m_fi(m + 1) = (j + C2) Mod nb
        m_fi(m + 2) = (j + C3) Mod nb
        m_ri(m) = (nb + j - C1) Mod nb
        m_ri(m + 1) = (nb + j - C2) Mod nb
        m_ri(m + 2) = (nb + j - C3) Mod nb
    Next

    N = m_Nb * (m_Nr + 1)

    For i = 0 To m_Nk - 1
        j = i * 4
        CipherKey(i) = PackFrom(Key, j)
    Next

    For i = 0 To m_Nk - 1
        m_fkey(i) = CipherKey(i)
    Next

    j = m_Nk
    k = 0
    Do While j < N
        m_fkey(j) = m_fkey(j - m_Nk) Xor _
               SubByte(RotateLeft(m_fkey(j - 1), 24)) Xor m_rco(k)
        If m_Nk <= 6 Then
            i = 1
            Do While i < m_Nk And (i + j) < N
                m_fkey(i + j) = m_fkey(i + j - m_Nk) Xor _
                       m_fkey(i + j - 1)
                i = i + 1
            Loop
        Else
            i = 1
            Do While i < 4 And (i + j) < N
                m_fkey(i + j) = m_fkey(i + j - m_Nk) Xor _
                       m_fkey(i + j - 1)
                i = i + 1
            Loop
            If j + 4 < N Then
                m_fkey(j + 4) = m_fkey(j + 4 - m_Nk) Xor _
                       SubByte(m_fkey(j + 3))
            End If
            i = 5
            Do While i < m_Nk And (i + j) < N
                m_fkey(i + j) = m_fkey(i + j - m_Nk) Xor _
                       m_fkey(i + j - 1)
                i = i + 1
            Loop
        End If

        j = j + m_Nk
        k = k + 1
    Loop

    For j = 0 To m_Nb - 1
        m_rkey(j + N - nb) = m_fkey(j)
    Next

    i = m_Nb
    Do While i < N - m_Nb
        k = N - m_Nb - i
        For j = 0 To m_Nb - 1
            m_rkey(k + j) = InvMixCol(m_fkey(i + j))
        Next
        i = i + m_Nb
    Loop

    j = N - m_Nb
    Do While j < N
        m_rkey(j - N + m_Nb) = m_fkey(j)
        j = j + 1
    Loop
End Sub

Public Sub encrypt(buff())
    Dim i
    Dim j
    Dim k
    Dim m
    Dim a(7)
    Dim b(7)
    Dim x
    Dim y
    Dim t

    For i = 0 To m_Nb - 1
        j = i * 4

        a(i) = PackFrom(buff, j)
        a(i) = a(i) Xor m_fkey(i)
    Next

    k = m_Nb
    x = a
    y = b

    For i = 1 To m_Nr - 1
        For j = 0 To m_Nb - 1
            m = j * 3
            y(j) = m_fkey(k) Xor m_ftable(x(j) And m_lOnBits(7)) Xor _
              RotateLeft(m_ftable(RShift(x(m_fi(m)), 8) And m_lOnBits(7)), 8) Xor _
              RotateLeft(m_ftable(RShift(x(m_fi(m + 1)), 16) And m_lOnBits(7)), 16) Xor _
              RotateLeft(m_ftable(RShift(x(m_fi(m + 2)), 24) And m_lOnBits(7)), 24)
            k = k + 1
        Next
        t = x
        x = y
        y = t
    Next

    For j = 0 To m_Nb - 1
        m = j * 3
        y(j) = m_fkey(k) Xor m_fbsub(x(j) And m_lOnBits(7)) Xor _
          RotateLeft(m_fbsub(RShift(x(m_fi(m)), 8) And m_lOnBits(7)), 8) Xor _
          RotateLeft(m_fbsub(RShift(x(m_fi(m + 1)), 16) And m_lOnBits(7)), 16) Xor _
          RotateLeft(m_fbsub(RShift(x(m_fi(m + 2)), 24) And m_lOnBits(7)), 24)
        k = k + 1
    Next

    For i = 0 To m_Nb - 1
        j = i * 4
        UnpackFrom y(i), buff, j
        x(i) = 0
        y(i) = 0
    Next
End Sub

Public Sub decrypt(buff())
    Dim i
    Dim j
    Dim k
    Dim m
    Dim a(7)
    Dim b(7)
    Dim x
    Dim y
    Dim t

    For i = 0 To m_Nb - 1
        j = i * 4
        a(i) = PackFrom(buff, j)
        a(i) = a(i) Xor m_rkey(i)
    Next

    k = m_Nb
    x = a
    y = b

    For i = 1 To m_Nr - 1
        For j = 0 To m_Nb - 1
            m = j * 3
            y(j) = m_rkey(k) Xor m_rtable(x(j) And m_lOnBits(7)) Xor _
              RotateLeft(m_rtable(RShift(x(m_ri(m)), 8) And m_lOnBits(7)), 8) Xor _
              RotateLeft(m_rtable(RShift(x(m_ri(m + 1)), 16) And m_lOnBits(7)), 16) Xor _
              RotateLeft(m_rtable(RShift(x(m_ri(m + 2)), 24) And m_lOnBits(7)), 24)
            k = k + 1
        Next
        t = x
        x = y
        y = t
    Next

    For j = 0 To m_Nb - 1
        m = j * 3

        y(j) = m_rkey(k) Xor m_rbsub(x(j) And m_lOnBits(7)) Xor _
          RotateLeft(m_rbsub(RShift(x(m_ri(m)), 8) And m_lOnBits(7)), 8) Xor _
          RotateLeft(m_rbsub(RShift(x(m_ri(m + 1)), 16) And m_lOnBits(7)), 16) Xor _
          RotateLeft(m_rbsub(RShift(x(m_ri(m + 2)), 24) And m_lOnBits(7)), 24)
        k = k + 1
    Next

    For i = 0 To m_Nb - 1
        j = i * 4

        UnpackFrom y(i), buff, j
        x(i) = 0
        y(i) = 0
    Next
End Sub

Private Function IsInitialized(vArray)
    On Error Resume Next

    IsInitialized = IsNumeric(UBound(vArray))
End Function

Private Sub CopyBytesASP(bytDest, lDestStart, bytSource(), lSourceStart, lLength)
    Dim lCount

    lCount = 0
    Do
        bytDest(lDestStart + lCount) = bytSource(lSourceStart + lCount)
        lCount = lCount + 1
    Loop Until lCount = lLength
End Sub

Public Function EncryptData(bytMessage, bytPassword)
    Dim bytKey(31)
    Dim bytIn()
    Dim bytOut()
    Dim bytTemp(31)
    Dim lCount
    Dim lLength
    Dim lEncodedLength
    Dim bytLen(3)
    Dim lPosition

    If Not IsInitialized(bytMessage) Then
        Exit Function
    End If
    If Not IsInitialized(bytPassword) Then
        Exit Function
    End If

    For lCount = 0 To UBound(bytPassword)
        bytKey(lCount) = bytPassword(lCount)
        If lCount = 31 Then
            Exit For
        End If
    Next

    gentables
    gkey 8, 8, bytKey

    lLength = UBound(bytMessage) + 1
    lEncodedLength = lLength + 4

    If lEncodedLength Mod 32 <> 0 Then
        lEncodedLength = lEncodedLength + 32 - (lEncodedLength Mod 32)
    End If
    ReDim bytIn(lEncodedLength - 1)
    ReDim bytOut(lEncodedLength - 1)

    Unpack lLength, bytIn
    CopyBytesASP bytIn, 4, bytMessage, 0, lLength

    For lCount = 0 To lEncodedLength - 1 Step 32
        CopyBytesASP bytTemp, 0, bytIn, lCount, 32
        Encrypt bytTemp
        CopyBytesASP bytOut, lCount, bytTemp, 0, 32
    Next

    EncryptData = bytOut
End Function

Public Function DecryptData(bytIn, bytPassword)
    Dim bytMessage()
    Dim bytKey(31)
    Dim bytOut()
    Dim bytTemp(31)
    Dim lCount
    Dim lLength
    Dim lEncodedLength
    Dim bytLen(3)
    Dim lPosition

    If Not IsInitialized(bytIn) Then
        Exit Function
    End If
    If Not IsInitialized(bytPassword) Then
        Exit Function
    End If

    lEncodedLength = UBound(bytIn) + 1

    If lEncodedLength Mod 32 <> 0 Then
        Exit Function
    End If

    For lCount = 0 To UBound(bytPassword)
        bytKey(lCount) = bytPassword(lCount)
        If lCount = 31 Then
            Exit For
        End If
    Next

    gentables
    gkey 8, 8, bytKey

    ReDim bytOut(lEncodedLength - 1)

    For lCount = 0 To lEncodedLength - 1 Step 32
        CopyBytesASP bytTemp, 0, bytIn, lCount, 32
        Decrypt bytTemp
        CopyBytesASP bytOut, lCount, bytTemp, 0, 32
    Next

    lLength = Pack(bytOut)

    If lLength > lEncodedLength - 4 Then
        Exit Function
    End If

    ReDim bytMessage(lLength - 1)
    CopyBytesASP bytMessage, 0, bytOut, 4, lLength

    DecryptData = bytMessage
End Function

8.一個(gè)日期轉(zhuǎn)換函數(shù)

Function FormatDate(byVal strDate, byVal strFormat)

    ' Accepts strDate as a valid date/time,
    ' strFormat as the output template.
    ' The function finds each item in the
    ' template and replaces it with the
    ' relevant information extracted from strDate.
    ' You are free to use this code provided the following line remains
    ' www.adopenstatic.com/resources/code/formatdate.asp

    ' Template items
    ' %m Month as a decimal no. 2
    ' %M Month as a padded decimal no. 02
    ' %B Full month name February
    ' %b Abbreviated month name Feb
    ' %d Day of the month eg 23
    ' %D Padded day of the month eg 09
    ' %O ordinal of day of month (eg st or rd or nd)
    ' %j Day of the year 54
    ' %Y Year with century 1998
    ' %y Year without century 98
    ' %w Weekday as integer (0 is Sunday)
    ' %a Abbreviated day name Fri
    ' %A Weekday Name Friday
    ' %H Hour in 24 hour format 24
    ' %h Hour in 12 hour format 12
    ' %N Minute as an integer 01
    ' %n Minute as optional if minute <> 00
    ' %S Second as an integer 55
    ' %P AM/PM Indicator PM

    On Error Resume Next

    Dim intPosItem
    Dim int12HourPart
    Dim str24HourPart
    Dim strMinutePart
    Dim strSecondPart
    Dim strAMPM

    ' Insert Month Numbers
    strFormat = Replace(strFormat, "%m", DatePart("m", strDate), 1, -1, vbBinaryCompare)

    ' Insert Padded Month Numbers
    strFormat = Replace(strFormat, "%M", Right("0" & DatePart("m", strDate), 2), 1, -1, vbBinaryCompare)

    ' Insert non-Abbreviated Month Names
    strFormat = Replace(strFormat, "%B", MonthName(DatePart("m", strDate), False), 1, -1, vbBinaryCompare)

    ' Insert Abbreviated Month Names
    strFormat = Replace(strFormat, "%b", MonthName(DatePart("m", strDate), True), 1, -1, vbBinaryCompare)

    ' Insert Day Of Month
    strFormat = Replace(strFormat, "%d", DatePart("d", strDate), 1, -1, vbBinaryCompare)

    ' Insert Padded Day Of Month
    strFormat = Replace(strFormat, "%D", Right ("0" & DatePart("d", strDate), 2), 1, -1, vbBinaryCompare)

    ' Insert Day of Month ordinal (eg st, th, or rd)
    strFormat = Replace(strFormat, "%O", GetDayOrdinal(Day(strDate)), 1, -1, vbBinaryCompare)

    ' Insert Day of Year
    strFormat = Replace(strFormat, "%j", DatePart("y", strDate), 1, -1, vbBinaryCompare)

    ' Insert Long Year (4 digit)
    strFormat = Replace(strFormat, "%Y", DatePart("yyyy", strDate), 1, -1, vbBinaryCompare)

    ' Insert Short Year (2 digit)
    strFormat = Replace(strFormat, "%y", Right(DatePart("yyyy", strDate), 2), 1, -1, vbBinaryCompare)

    ' Insert Weekday as Integer (eg 0 = Sunday)
    strFormat = Replace(strFormat, "%w", DatePart("w", strDate, 1), 1, -1, vbBinaryCompare)

    ' Insert Abbreviated Weekday Name (eg Sun)
    strFormat = Replace(strFormat, "%a", WeekdayName(DatePart("w", strDate, 1), True), 1, -1, vbBinaryCompare)

    ' Insert non-Abbreviated Weekday Name
    strFormat = Replace(strFormat, "%A", WeekdayName(DatePart("w", strDate, 1), False), 1, -1, vbBinaryCompare)

    ' Insert Hour in 24hr format
    str24HourPart = DatePart("h", strDate)
    If Len(str24HourPart) < 2 Then str24HourPart = "0" & str24HourPart
    strFormat = Replace(strFormat, "%H", str24HourPart, 1, -1, vbBinaryCompare)

    ' Insert Hour in 12hr format
    int12HourPart = DatePart("h", strDate) Mod 12
    If int12HourPart = 0 Then int12HourPart = 12
    strFormat = Replace(strFormat, "%h", int12HourPart, 1, -1, vbBinaryCompare)

    ' Insert Minutes
    strMinutePart = DatePart("n", strDate)
    If Len(strMinutePart) < 2 Then strMinutePart = "0" & strMinutePart
    strFormat = Replace(strFormat, "%N", strMinutePart, 1, -1, vbBinaryCompare)

    ' Insert Optional Minutes
    If CInt(strMinutePart) = 0 Then
        strFormat = Replace(strFormat, "%n", "", 1, -1, vbBinaryCompare)
    Else
        If CInt(strMinutePart) < 10 Then strMinutePart = "0" & strMinutePart
        strMinutePart = ":" & strMinutePart
        strFormat = Replace(strFormat, "%n", strMinutePart, 1, -1, vbBinaryCompare)
    End If

    ' Insert Seconds
    strSecondPart = DatePart("s", strDate)
    If Len(strSecondPart) < 2 Then strSecondPart = "0" & strSecondPart
    strFormat = Replace(strFormat, "%S", strSecondPart, 1, -1, vbBinaryCompare)

    ' Insert AM/PM indicator
    If DatePart("h", strDate) >= 12 Then
        strAMPM = "PM"
    Else
        strAMPM = "AM"
    End If

    strFormat = Replace(strFormat, "%P", strAMPM, 1, -1, vbBinaryCompare)

    FormatDate = strFormat

End Function

Function GetDayOrdinal( _
                       byVal intDay _
                       )

    ' Accepts a day of the month
    ' as an integer and returns the
    ' appropriate suffix
    On Error Resume Next

    Dim strOrd

    Select Case intDay
        Case 1, 21, 31
            strOrd = "st"
        Case 2, 22
            strOrd = "nd"
        Case 3, 23
            strOrd = "rd"
        Case Else
            strOrd = "th"
    End Select

    GetDayOrdinal = strOrd

End Function
%>
<%
Dim db
db = "dbms.mdb"

'******************************************************************
'執(zhí)行sql語(yǔ)句,不返回值,sql語(yǔ)句最好是如下:
'update 表名 set 字段名=value,字段名=value where 字段名=value
'delete from 表名 where 字段名=value
'insert into 表名 (字段名,字段名) values (value,value)
'******************************************************************

Sub NoResult(sql)
    Dim conn
    Dim connstr
    Set conn = Server.CreateObject("ADODB.Connection")
    connstr = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & Server.MapPath(""&db&"")
    conn.Open connstr
    conn.Execute sql
    conn.Close
    Set conn = Nothing
End Sub

'*******************************************************************
'執(zhí)行select語(yǔ)句,返回recordset對(duì)象。該對(duì)象只讀。也就是不能更新
'*******************************************************************

Function Result(sql)
    Dim conn
    Dim connstr
    Dim rcs
    Set conn = Server.CreateObject("ADODB.Connection")
    connstr = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & Server.MapPath(""&db&"")
    conn.Open connstr
    Set rcs = Server.CreateObject("ADODB.Recordset")
    rcs.Open sql, conn, 1, 1
    Set Result = rcs
End Function

'*******************************************************************
' 彈出對(duì)話框
'*******************************************************************

Sub alert(message)
    message = Replace(message, "'", "\'")
    Response.Write ("<script>alert('" & message & "')</script>")
End Sub

'*******************************************************************
' 返回上一頁(yè),一般用在判斷信息提交是否完全之后
'*******************************************************************

Sub GoBack()
    Response.Write ("<script>history.go(-1)</script>")
End Sub

'*******************************************************************
' 重定向另外的連接
'*******************************************************************

Sub Go(url)
    Response.Write ("<script>location.href('" & url & "')</script>")
End Sub

'*******************************************************************
' 把html標(biāo)記替換
'*******************************************************************

Function htmlencode2(Str)
    Dim result
    Dim l
    If IsNull(Str) Then
        htmlencode2 = ""
        Exit Function
    End If
    l = Len(Str)
    result = ""
    Dim i
    For i = 1 To l
        Select Case Mid(Str, i, 1)
            Case "<"
                result = result + "<"
            Case ">"
                result = result + ">"
            Case Chr(13)
                result = result + "<br>"
            Case Chr(34)
                result = result + """%>
<%
cLeft(String, Length) 返回指定數(shù)目的從字符串的左邊算起的字符,區(qū)分單雙字節(jié)。

如:
Dim MyString, LeftString
MyString = "文字測(cè)試VBSCript"
LeftString = cLeft(MyString, 10)
返回 "文字測(cè)試VB"。

MyRandc(n) 生成隨機(jī)字符,n為字符的個(gè)數(shù)

如:
response.Write MyRandn(10)
輸出10個(gè)隨機(jī)字符

MyRandn(n) 生成隨機(jī)數(shù)字,n為數(shù)字的個(gè)數(shù)

如:
response.Write MyRandn(10)
輸出10個(gè)隨機(jī)數(shù)字

formatQueryStr(Str) 格式化sql中的like字符串.
如:
q = Request("q")
q = formatQueryStr(q)
sql = "select * from [table] where aa like '%"& q &"%'"

GetRnd(min, max) 返回min - max之間的一個(gè)隨機(jī)數(shù)

如:
response.Write GetRnd(100, 200)
輸出大于100到200之間的一個(gè)隨機(jī)數(shù)

Function cLeft(Str, n)
    Dim str1, str2, alln, Islefted
    str2 = ""
    alln = 0
    str1 = Str
    Islefted = False
    If IsNull(Str) Then
        cleft = ""
        Exit Function
    End If
    For i = 1 To Len(str1)
        nowstr = Mid(str1, i, 1)
        If Asc(nowstr)<0 Then
            alln = alln + 2
        Else
            alln = alln + 1
        End If
        If (alln<= n) Then
            str2 = str2 & nowstr
        Else
            Islefted = True
            Exit For
        End If
    Next
    If Islefted Then
        str2 = str2 & ".."
    End If
    cleft = str2
End Function

Function MyRandc(n) '生成隨機(jī)字符,n為字符的個(gè)數(shù)
    Dim thechr
    thechr = ""
    For i = 1 To n
        Dim zNum, zNum2
        Randomize
        zNum = CInt(25 * Rnd)
        zNum2 = CInt(10 * Rnd)
        If zNum2 Mod 2 = 0 Then
            zNum = zNum + 97
        Else
            zNum = zNum + 65
        End If
        thechr = thechr & Chr(zNum)
    Next
    MyRandc = thechr
End Function

Function MyRandn(n) '生成隨機(jī)數(shù)字,n為數(shù)字的個(gè)數(shù)
    Dim thechr
    thechr = ""
    For i = 1 To n
        Dim zNum, zNum2
        Randomize
        zNum = CInt(9 * Rnd)
        zNum = zNum + 48
        thechr = thechr & Chr(zNum)
    Next
    MyRandn = thechr
End Function

Function formatQueryStr(Str) '格式化sql中的like字符串
    Dim nstr
    nstr = Str
    nstr = Replace(nstr, Chr(0), "")
    nstr = Replace(nstr, "'", "''")
    nstr = Replace(nstr, "[", "[[]")
    nstr = Replace(nstr, "%", "[%]")
    formatQueryStr = nstr
End Function

Function GetRnd(min, max)
    Randomize
    GetRnd = Int((max - min + 1) * Rnd + min)
End Function


'*******************************************************************
'取得IP地址
'*******************************************************************

Function Userip()
    Dim GetClientIP
    '如果客戶端用了代理服務(wù)器,則應(yīng)該用ServerVariables("HTTP_X_FORWARDED_FOR")方法
    GetClientIP = Request.ServerVariables("HTTP_X_FORWARDED_FOR")
    If GetClientIP = "" or IsNull(GetClientIP) or IsEmpty(GetClientIP) Then
        '如果客戶端沒用代理,應(yīng)該用Request.ServerVariables("REMOTE_ADDR")方法
        GetClientIP = Request.ServerVariables("REMOTE_ADDR")
    End If
    Userip = GetClientIP
End Function


'*******************************************************************
'轉(zhuǎn)換IP地址
'*******************************************************************

Function cip(sip)
    tip = CStr(sip)
    sip1 = Left(tip, CInt(InStr(tip, ".") -1))
    tip = Mid(tip, CInt(InStr(tip, ".") + 1))
    sip2 = Left(tip, CInt(InStr(tip, ".") -1))
    tip = Mid(tip, CInt(InStr(tip, ".") + 1))
    sip3 = Left(tip, CInt(InStr(tip, ".") -1))
    sip4 = Mid(tip, CInt(InStr(tip, ".") + 1))
    cip = CInt(sip1) * 256 * 256 * 256 + CInt(sip2) * 256 * 256 + CInt(sip3) * 256 + CInt(sip4)
End Function


'*******************************************************************
' 彈出對(duì)話框
'*******************************************************************

Sub alert(message)
    message = Replace(message, "'", "\'")
    Response.Write ("<script>alert('" & message & "')</script>")
End Sub

'*******************************************************************
' 返回上一頁(yè),一般用在判斷信息提交是否完全之后
'*******************************************************************

Sub GoBack()
    Response.Write ("<script>history.go(-1)</script>")
End Sub


'*******************************************************************
' 重定向另外的連接
'*******************************************************************

Sub Go(url)
    Response.Write ("<script>location.href('" & url & "')</script>")
End Sub


'*******************************************************************
' 指定秒數(shù)重定向另外的連接
'*******************************************************************

Sub GoPage(url, s)
    s = s * 1000
    Response.Write "<SCRIPT LANGUAGE=javascript>"
    Response.Write "window.setTimeout("&Chr(34)&"window.navigate('"&url&"')"&Chr(34)&","&s&")"
    Response.Write "</script>"
End Sub


'*******************************************************************
' 判斷數(shù)字是否整形
'*******************************************************************

Function isInteger(para)
    On Error Resume Next
    Dim Str
    Dim l, i
    If IsNull(para) Then
        isInteger = False
        Exit Function
    End If
    Str = CStr(para)
    If Trim(Str) = "" Then
        isInteger = False
        Exit Function
    End If
    l = Len(Str)
    For i = 1 To l
        If Mid(Str, i, 1)>"9" or Mid(Str, i, 1)<"0" Then
            isInteger = False
            Exit Function
        End If
    Next
    isInteger = True
    If Err.Number<>0 Then Err.Clear
End Function


'*******************************************************************
' 獲得文件擴(kuò)展名
'*******************************************************************

Function GetExtend(filename)
    Dim tmp
    If filename<>"" Then
        tmp = Mid(filename, instrrev(filename, ".") + 1, Len(filename) - instrrev(filename, "."))
        tmp = LCase(tmp)
        If InStr(1, tmp, "asp")>0 or InStr(1, tmp, "php")>0 or InStr(1, tmp, "php3")>0 or InStr(1, tmp, "aspx")>0 Then
            getextend = "txt"
        Else
            getextend = tmp
        End If
    Else
        getextend = ""
    End If
End Function


' *----------------------------------------------------------------------------
' * 函數(shù):CheckIn
' * 描述:檢測(cè)參數(shù)是否有SQL危險(xiǎn)字符
' * 參數(shù):str要檢測(cè)的數(shù)據(jù)
' * 返回:FALSE:安全 TRUE:不安全
' * 作者:
' * 日期:
' *----------------------------------------------------------------------------

Function CheckIn(Str)
    If InStr(1, Str, Chr(39))>0 or InStr(1, Str, Chr(34))>0 or InStr(1, Str, Chr(59))>0 Then
        CheckIn = True
    Else
        CheckIn = False
    End If
End Function


' *----------------------------------------------------------------------------
' * 函數(shù):HTMLEncode
' * 描述:過(guò)濾HTML代碼
' * 參數(shù):--
' * 返回:--
' * 作者:
' * 日期:
' *----------------------------------------------------------------------------

Function HTMLEncode(fString)
    If Not IsNull(fString) Then
        fString = Replace(fString, ">", ">")
        fString = Replace(fString, "<", "<")

        fString = Replace(fString, Chr(32), " ")
        fString = Replace(fString, Chr(9), " ")
        fString = Replace(fString, Chr(34), """)
        fString = Replace(fString, Chr(39), "'")
        fString = Replace(fString, Chr(13), "")
        fString = Replace(fString, Chr(10) & Chr(10), "</P><P> ")
        fString = Replace(fString, Chr(10), "<BR> ")

        HTMLEncode = fString
    End If
End Function


' *----------------------------------------------------------------------------
' * 函數(shù):HTMLcode
' * 描述:過(guò)濾表單字符
' * 參數(shù):--
' * 返回:--
' * 作者:
' * 日期:
' *----------------------------------------------------------------------------

Function HTMLcode(fString)
    If Not IsNull(fString) Then
        fString = Replace(fString, Chr(13), "")
        fString = Replace(fString, Chr(10) & Chr(10), "</P><P>")
        fString = Replace(fString, Chr(34), "")
        fString = Replace(fString, Chr(10), "<BR>")
        HTMLcode = fString
    End If
End Function


%>
<%
cLeft(String, Length) 返回指定數(shù)目的從字符串的左邊算起的字符,區(qū)分單雙字節(jié)。
如:
Dim MyString, LeftString
MyString = "文字測(cè)試VBSCript"
LeftString = cLeft(MyString, 10)
返回 "文字測(cè)試VB"。
MyRandc(n) 生成隨機(jī)字符,n為字符的個(gè)數(shù)
如:
response.Write MyRandn(10)
輸出10個(gè)隨機(jī)字符
MyRandn(n) 生成隨機(jī)數(shù)字,n為數(shù)字的個(gè)數(shù)
如:
response.Write MyRandn(10)
輸出10個(gè)隨機(jī)數(shù)字
formatQueryStr(Str) 格式化sql中的like字符串.
如:
q = Request("q")
q = formatQueryStr(q)
sql = "select * from [table] where aa like '%"& q &"%'"
GetRnd(min, max) 返回min - max之間的一個(gè)隨機(jī)數(shù)
如:
response.Write GetRnd(100, 200)
輸出大于100到200之間的一個(gè)隨機(jī)數(shù)

Function cLeft(Str, n)
    Dim str1, str2, alln, Islefted
    str2 = ""
    alln = 0
    str1 = Str
    Islefted = False
    If IsNull(Str) Then
        cleft = ""
        Exit Function
    End If
    For i = 1 To Len(str1)
        nowstr = Mid(str1, i, 1)
        If Asc(nowstr)<0 Then
            alln = alln + 2
        Else
            alln = alln + 1
        End If
        If (alln<= n) Then
            str2 = str2 & nowstr
        Else
            Islefted = True
            Exit For
        End If
    Next
    If Islefted Then
        str2 = str2 & ".."
    End If
    cleft = str2
End Function


Function MyRandc(n) '生成隨機(jī)字符,n為字符的個(gè)數(shù)
    Dim thechr
    thechr = ""
    For i = 1 To n
        Dim zNum, zNum2
        Randomize
        zNum = CInt(25 * Rnd)
        zNum2 = CInt(10 * Rnd)
        If zNum2 Mod 2 = 0 Then
            zNum = zNum + 97
        Else
            zNum = zNum + 65
        End If
        thechr = thechr & Chr(zNum)
    Next
    MyRandc = thechr
End Function


Function MyRandn(n) '生成隨機(jī)數(shù)字,n為數(shù)字的個(gè)數(shù)
    Dim thechr
    thechr = ""
    For i = 1 To n
        Dim zNum, zNum2
        Randomize
        zNum = CInt(9 * Rnd)
        zNum = zNum + 48
        thechr = thechr & Chr(zNum)
    Next
    MyRandn = thechr
End Function


Function formatQueryStr(Str) '格式化sql中的like字符串
    Dim nstr
    nstr = Str
    nstr = Replace(nstr, Chr(0), "")
    nstr = Replace(nstr, "'", "''")
    nstr = Replace(nstr, "[", "[[]")
    nstr = Replace(nstr, "%", "[%]")
    formatQueryStr = nstr
End Function


Function GetRnd(min, max)
    Randomize
    GetRnd = Int((max - min + 1) * Rnd + min)
End Function

'*******************************************************************
'取得IP地址
'*******************************************************************

Function Userip()
    Dim GetClientIP
    '如果客戶端用了代理服務(wù)器,則應(yīng)該用ServerVariables("HTTP_X_FORWARDED_FOR")方法
    GetClientIP = Request.ServerVariables("HTTP_X_FORWARDED_FOR")
    If GetClientIP = "" or IsNull(GetClientIP) or IsEmpty(GetClientIP) Then
        '如果客戶端沒用代理,應(yīng)該用Request.ServerVariables("REMOTE_ADDR")方法
        GetClientIP = Request.ServerVariables("REMOTE_ADDR")
    End If
    Userip = GetClientIP
End Function

'*******************************************************************
'轉(zhuǎn)換IP地址
'*******************************************************************

Function cip(sip)
    tip = CStr(sip)
    sip1 = Left(tip, CInt(InStr(tip, ".") -1))
    tip = Mid(tip, CInt(InStr(tip, ".") + 1))
    sip2 = Left(tip, CInt(InStr(tip, ".") -1))
    tip = Mid(tip, CInt(InStr(tip, ".") + 1))
    sip3 = Left(tip, CInt(InStr(tip, ".") -1))
    sip4 = Mid(tip, CInt(InStr(tip, ".") + 1))
    cip = CInt(sip1) * 256 * 256 * 256 + CInt(sip2) * 256 * 256 + CInt(sip3) * 256 + CInt(sip4)
End Function

'*******************************************************************
' 彈出對(duì)話框
'*******************************************************************

Sub alert(message)
    message = Replace(message, "'", "\'")
    Response.Write ("<script>alert('" & message & "')</script>")
End Sub

'*******************************************************************
' 返回上一頁(yè),一般用在判斷信息提交是否完全之后
'*******************************************************************

Sub GoBack()
    Response.Write ("<script>history.go(-1)</script>")
End Sub

'*******************************************************************
' 重定向另外的連接
'*******************************************************************

Sub Go(url)
    Response.Write ("<script>location.href('" & url & "')</script>")
End Sub

'*******************************************************************
' 指定秒數(shù)重定向另外的連接
'*******************************************************************

Sub GoPage(url, s)
    s = s * 1000
    Response.Write "<SCRIPT LANGUAGE=javascript>"
    Response.Write "window.setTimeout("&Chr(34)&"window.navigate('"&url&"')"&Chr(34)&","&s&")"
    Response.Write "</script>"
End Sub

'*******************************************************************
' 判斷數(shù)字是否整形
'*******************************************************************

Function isInteger(para)
    On Error Resume Next
    Dim Str
    Dim l, i
    If IsNull(para) Then
        isInteger = False
        Exit Function
    End If
    Str = CStr(para)
    If Trim(Str) = "" Then
        isInteger = False
        Exit Function
    End If
    l = Len(Str)
    For i = 1 To l
        If Mid(Str, i, 1)>"9" or Mid(Str, i, 1)<"0" Then
            isInteger = False
            Exit Function
        End If
    Next
    isInteger = True
    If Err.Number<>0 Then Err.Clear
End Function

'*******************************************************************
' 獲得文件擴(kuò)展名
'*******************************************************************

Function GetExtend(filename)
    Dim tmp
    If filename<>"" Then
        tmp = Mid(filename, instrrev(filename, ".") + 1, Len(filename) - instrrev(filename, "."))
        tmp = LCase(tmp)
        If InStr(1, tmp, "asp")>0 or InStr(1, tmp, "php")>0 or InStr(1, tmp, "php3")>0 or InStr(1, tmp, "aspx")>0 Then
            getextend = "txt"
        Else
            getextend = tmp
        End If
    Else
        getextend = ""
    End If
End Function

' *----------------------------------------------------------------------------
' * 函數(shù):CheckIn
' * 描述:檢測(cè)參數(shù)是否有SQL危險(xiǎn)字符
' * 參數(shù):str要檢測(cè)的數(shù)據(jù)
' * 返回:FALSE:安全 TRUE:不安全
' * 作者:
' * 日期:
' *----------------------------------------------------------------------------

Function CheckIn(Str)
    If InStr(1, Str, Chr(39))>0 or InStr(1, Str, Chr(34))>0 or InStr(1, Str, Chr(59))>0 Then
        CheckIn = True
    Else
        CheckIn = False
    End If
End Function

' *----------------------------------------------------------------------------
' * 函數(shù):HTMLEncode
' * 描述:過(guò)濾HTML代碼
' * 參數(shù):--
' * 返回:--
' * 作者:
' * 日期:
' *----------------------------------------------------------------------------

Function HTMLEncode(fString)
    If Not IsNull(fString) Then
        fString = Replace(fString, ">", ">")
        fString = Replace(fString, "<", "<")
        fString = Replace(fString, Chr(32), " ")
        fString = Replace(fString, Chr(9), " ")
        fString = Replace(fString, Chr(34), """)
        fString = Replace(fString, Chr(39), "'")
        fString = Replace(fString, Chr(13), "")
        fString = Replace(fString, Chr(10) & Chr(10), "</P><P> ")
        fString = Replace(fString, Chr(10), "<BR> ")
        HTMLEncode = fString
    End If
End Function

' *----------------------------------------------------------------------------
' * 函數(shù):HTMLcode
' * 描述:過(guò)濾表單字符
' * 參數(shù):--
' * 返回:--
' * 作者:
' * 日期:
' *----------------------------------------------------------------------------

Function HTMLcode(fString)
    If Not IsNull(fString) Then
        fString = Replace(fString, Chr(13), "")
        fString = Replace(fString, Chr(10) & Chr(10), "</P><P>")
        fString = Replace(fString, Chr(34), "")
        fString = Replace(fString, Chr(10), "<BR>")
        HTMLcode = fString
    End If
End Function
%>
11.ACCESS數(shù)據(jù)庫(kù)連接:
<%
Option Explicit
Dim startime, endtime, conn, connstr, db
startime = Timer()
'更改數(shù)據(jù)庫(kù)名字
db = "data/dvBBS5.mdb"
Set conn = Server.CreateObject("ADODB.Connection")
connstr = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & Server.MapPath(db)
'如果你的服務(wù)器采用較老版本Access驅(qū)動(dòng),請(qǐng)用下面連接方法
'connstr="driver={Microsoft Access Driver (*.mdb)};dbq=" & Server.MapPath(db)
conn.Open connstr

Function CloseDatabase
    Conn.Close
    Set conn = Nothing
End Function
%>
12.SQL數(shù)據(jù)庫(kù)連接:
<%
Option Explicit
Dim startime, endtime, conn, connstr, db
startime = Timer()
connstr = "driver={SQL Server};server=HUDENQ-N11T33NB;uid=sa;pwd=xsfeihu;database=dvbbs"
Set conn = Server.CreateObject("ADODB.Connection")
conn.Open connstr

Function CloseDatabase
    Conn.Close
    Set conn = Nothing
End Function
%>
13.用鍵盤打開網(wǎng)頁(yè)代碼:
<script language="javascript">
function ctlent(eventobject)
{
if((event.ctrlKey && window.event.keyCode==13)||(event.altKey && window.event.keyCode==83))
{
window.open('網(wǎng)址','','')
}
}
</script> 
這里是Ctrl+Enter和Alt+S的代碼 自己查下鍵盤的ASCII碼再換就行
14.讓層不被控件復(fù)蓋代碼:
<div z-Index:2><object ***></object></div> # 前面
<div z-Index:1><object ***></object></div> # 后面
<div id="Layer2" style="position:absolute; top:40;width:400px; height:95px;z-index:2"><table height=100% width=100% bgcolor="#ff0000"><tr><td height=100% width=100%></td></tr></table><iframe width=0 height=0></iframe></div>
<div id="Layer1" style="position:absolute; top:50;width:200px; height:115px;z-index:1"><iframe height=100% width=100%></iframe></div>
15.動(dòng)網(wǎng)FLASH廣告代碼:
<object classid="clsid27CDB6E-AE6D-11cf-96B8-444553540000" codebase="http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=5,0,0,0" width="468" height="60"><param name=movie value="images/yj16d.swf"><param name=quality value=high><embed src="images/dvbanner.swf" quality=high pluginspage="http://www.macromedia.com/shockwave/download/index.cgi?P1_Prod_Version=ShockwaveFlash";;; type="application/x-shockwave-flash" width="468" height="60"></embed></object>
16.VBS彈出窗口小代碼:
<script language=vbscript>
msgbox"你還沒有注冊(cè)或登陸論壇","0","精品論壇"
location.href = "login.asp"
</script>
16.使用FSO修改文件特定內(nèi)容的函數(shù)
<%
Function FSOchange(filename, Target, String)
    Dim objFSO, objCountFile, FiletempData
    Set objFSO = Server.CreateObject("Scripting.FileSystemObject")
    Set objCountFile = objFSO.OpenTextFile(Server.MapPath(filename), 1, True)
    FiletempData = objCountFile.ReadAll
    objCountFile.Close
    FiletempData = Replace(FiletempData, Target, String)
    Set objCountFile = objFSO.CreateTextFile(Server.MapPath(filename), True)
    objCountFile.Write FiletempData
    objCountFile.Close
    Set objCountFile = Nothing
    Set objFSO = Nothing
End Function
%>
17.使用FSO讀取文件內(nèi)容的函數(shù)
<%
Function FSOFileRead(filename)
    Dim objFSO, objCountFile, FiletempData
    Set objFSO = Server.CreateObject("Scripting.FileSystemObject")
    Set objCountFile = objFSO.OpenTextFile(Server.MapPath(filename), 1, True)
    FSOFileRead = objCountFile.ReadAll
    objCountFile.Close
    Set objCountFile = Nothing
    Set objFSO = Nothing
End Function
%>
18.使用FSO讀取文件某一行的函數(shù)
<%
Function FSOlinedit(filename, lineNum)
    If linenum < 1 Then Exit Function
    Dim fso, f, temparray, tempcnt
    Set fso = server.CreateObject("scripting.filesystemobject")
    If Not fso.FileExists(server.mappath(filename)) Then Exit Function
    Set f = fso.OpenTextFile(server.mappath(filename), 1)
    If Not f.AtEndOfStream Then
        tempcnt = f.ReadAll
        f.Close
        Set f = Nothing
        temparray = Split(tempcnt, Chr(13)&Chr(10))
        If lineNum>UBound(temparray) + 1 Then
            Exit Function
        Else
            FSOlinedit = temparray(lineNum -1)
        End If
    End If
End Function
%>
19.使用FSO寫文件某一行的函數(shù)
<%
Function FSOlinewrite(filename, lineNum, Linecontent)
    If linenum < 1 Then Exit Function
    Dim fso, f, temparray, tempCnt
    Set fso = server.CreateObject("scripting.filesystemobject")
    If Not fso.FileExists(server.mappath(filename)) Then Exit Function
    Set f = fso.OpenTextFile(server.mappath(filename), 1)
    If Not f.AtEndOfStream Then
        tempcnt = f.ReadAll
        f.Close
        temparray = Split(tempcnt, Chr(13)&Chr(10))
        If lineNum>UBound(temparray) + 1 Then
            Exit Function
        Else
            temparray(lineNum -1) = lineContent
        End If
        tempcnt = Join(temparray, Chr(13)&Chr(10))
        Set f = fso.CreateTextFile(server.mappath(filename), True)
        f.Write tempcnt
    End If
    f.Close
    Set f = Nothing
End Function
%>
20.使用FSO添加文件新行的函數(shù)
<%
Function FSOappline(filename, Linecontent)
    Dim fso, f
    Set fso = server.CreateObject("scripting.filesystemobject")
    If Not fso.FileExists(server.mappath(filename)) Then Exit Function
    Set f = fso.OpenTextFile(server.mappath(filename), 8, 1)
    f.Write Chr(13)&Chr(10)&Linecontent
    f.Close
    Set f = Nothing
End Function
%>
21.讀文件最后一行的函數(shù)
<%
Function FSOlastline(filename)
    Dim fso, f, temparray, tempcnt
    Set fso = server.CreateObject("scripting.filesystemobject")
    If Not fso.FileExists(server.mappath(filename)) Then Exit Function
    Set f = fso.OpenTextFile(server.mappath(filename), 1)
    If Not f.AtEndOfStream Then
        tempcnt = f.ReadAll
        f.Close
        Set f = Nothing
        temparray = Split(tempcnt, Chr(13)&Chr(10))
        FSOlastline = temparray(UBound(temparray))
    End If
End Function
%>
利用FSO取得BMP,JPG,PNG,GIF文件信息(大小,寬、高等)
<%
'::: BMP, GIF, JPG and PNG ::: 
'::: This function gets a specified number of bytes from any :::
'::: file, starting at the offset (base 1) :::
'::: :::
'::: Passed: :::
'::: flnm => Filespec of file to read :::
'::: offset => Offset at which to start reading :::
'::: bytes => How many bytes to read :::
'::: :::
':::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::

Function GetBytes(flnm, offset, bytes)
    Dim objFSO
    Dim objFTemp
    Dim objTextStream
    Dim lngSize
    On Error Resume Next
    Set objFSO = CreateObject("Scripting.FileSystemObject") 
    ' First, we get the filesize
    Set objFTemp = objFSO.GetFile(flnm)
    lngSize = objFTemp.Size
    Set objFTemp = Nothing
    fsoForReading = 1
    Set objTextStream = objFSO.OpenTextFile(flnm, fsoForReading)
    If offset > 0 Then
        strBuff = objTextStream.Read(offset - 1)
    End If
    If bytes = -1 Then ' Get All!
        GetBytes = objTextStream.Read(lngSize) 'ReadAll
    Else
        GetBytes = objTextStream.Read(bytes)
    End If
    objTextStream.Close
    Set objTextStream = Nothing
    Set objFSO = Nothing
End Function 

':::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
'::: :::
'::: Functions to convert two bytes to a numeric value (long) :::
'::: (both little-endian and big-endian) :::
'::: :::
':::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::

Function lngConvert(strTemp)
    lngConvert = CLng(Asc(Left(strTemp, 1)) + ((Asc(Right(strTemp, 1)) * 256)))
End Function


Function lngConvert2(strTemp)
    lngConvert2 = CLng(Asc(Right(strTemp, 1)) + ((Asc(Left(strTemp, 1)) * 256)))
End Function 

':::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
'::: :::
'::: This function does most of the real work. It will attempt :::
'::: to read any file, regardless of the extension, and will :::
'::: identify if it is a graphical image. :::
'::: :::
'::: Passed: :::
'::: flnm => Filespec of file to read :::
'::: width => width of image :::
'::: height => height of image :::
'::: depth => color depth (in number of colors) :::
'::: strImageType=> type of image (e.g. GIF, BMP, etc.) :::
'::: :::
':::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::

Function gfxSpex(flnm, Width, height, depth, strImageType)
    Dim strPNG
    Dim strGIF
    Dim strBMP
    Dim strType
    strType = ""
    strImageType = "(unknown)"
    gfxSpex = False
    strPNG = Chr(137) & Chr(80) & Chr(78)
    strGIF = "GIF"
    strBMP = Chr(66) & Chr(77)
    strType = GetBytes(flnm, 0, 3)
    If strType = strGIF Then ' is GIF
        strImageType = "GIF"
        Width = lngConvert(GetBytes(flnm, 7, 2))
        Height = lngConvert(GetBytes(flnm, 9, 2))
        Depth = 2 ^ ((Asc(GetBytes(flnm, 11, 1)) And 7) + 1)
        gfxSpex = True
    ElseIf Left(strType, 2) = strBMP Then ' is BMP
        strImageType = "BMP"
        Width = lngConvert(GetBytes(flnm, 19, 2))
        Height = lngConvert(GetBytes(flnm, 23, 2))
        Depth = 2 ^ (Asc(GetBytes(flnm, 29, 1)))
        gfxSpex = True
    ElseIf strType = strPNG Then ' Is PNG
        strImageType = "PNG"
        Width = lngConvert2(GetBytes(flnm, 19, 2))
        Height = lngConvert2(GetBytes(flnm, 23, 2))
        Depth = getBytes(flnm, 25, 2)
        Select Case Asc(Right(Depth, 1))
            Case 0
                Depth = 2 ^ (Asc(Left(Depth, 1)))
                gfxSpex = True
            Case 2
                Depth = 2 ^ (Asc(Left(Depth, 1)) * 3)
                gfxSpex = True
            Case 3
                Depth = 2 ^ (Asc(Left(Depth, 1))) '8
                gfxSpex = True
            Case 4
                Depth = 2 ^ (Asc(Left(Depth, 1)) * 2)
                gfxSpex = True
            Case 6
                Depth = 2 ^ (Asc(Left(Depth, 1)) * 4)
                gfxSpex = True
            Case Else
                Depth = -1
        End Select 
    Else
        strBuff = GetBytes(flnm, 0, -1) ' Get all bytes from file
        lngSize = Len(strBuff)
        flgFound = 0
        strTarget = Chr(255) & Chr(216) & Chr(255)
        flgFound = InStr(strBuff, strTarget)
        If flgFound = 0 Then
            Exit Function
        End If
        strImageType = "JPG"
        lngPos = flgFound + 2
        ExitLoop = False
        Do While ExitLoop = False And lngPos < lngSize 
            Do While Asc(Mid(strBuff, lngPos, 1)) = 255 And lngPos < lngSize
                lngPos = lngPos + 1
            Loop
            If Asc(Mid(strBuff, lngPos, 1)) < 192 or Asc(Mid(strBuff, lngPos, 1)) > 195 Then
                lngMarkerSize = lngConvert2(Mid(strBuff, lngPos + 1, 2))
                lngPos = lngPos + lngMarkerSize + 1
            Else
                ExitLoop = True
            End If
        Loop
        '
        If ExitLoop = False Then
            Width = -1
            Height = -1
            Depth = -1
        Else
            Height = lngConvert2(Mid(strBuff, lngPos + 4, 2))
            Width = lngConvert2(Mid(strBuff, lngPos + 6, 2))
            Depth = 2 ^ (Asc(Mid(strBuff, lngPos + 8, 1)) * 8)
            gfxSpex = True
        End If 
    End If
End Function 

':::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
'::: Test Harness :::
'::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::: 
' To test, we'll just try to show all files with a .GIF extension in the root of C:
Set objFSO = CreateObject("Scripting.FileSystemObject")
Set objF = objFSO.GetFolder("c:\")
Set objFC = objF.Files
response.Write "<table border=""0"" cellpadding=""5"">"
For Each f1 in objFC
    If InStr(UCase(f1.Name), ".GIF") Then
        response.Write "<tr><td>" & f1.Name & "</td><td>" & f1.DateCreated & "</td><td>" & f1.Size & "</td><td>"
        If gfxSpex(f1.Path, w, h, c, strType) = True Then
            response.Write w & " x " & h & " " & c & " colors"
        Else
            response.Write " "
        End If
        response.Write "</td></tr>"
    End If
Next
response.Write "</table>"
Set objFC = Nothing
Set objF = Nothing
Set objFSO = Nothing 
%>
24.點(diǎn)擊返回上頁(yè)代碼:
<form>
<p><input TYPE="button" value="返回上一步" onCLICK="history.back(-1)"></p>
</form>
24.點(diǎn)擊刷新代碼:
<form>
<p><input TYPE="button" value="刷新按鈕一" onCLICK="ReloadButton()"></p>
</form>
<script language="javascript"><!--
function ReloadButton(){location.href="allbutton.htm";}
// --></script> 
24.點(diǎn)擊刷新代碼2:
<form>
<p><input TYPE="button" value="刷新按鈕二" onClick="history.go(0)"> </p>
</form> 
<form>
<p><input TYPE="button" value="打開一個(gè)網(wǎng)站" onCLICK="HomeButton()"></p>
</form>
<script language="javascript"><!--
function HomeButton(){location.;;;}
// --></script> 
25.彈出警告框代碼:
<form>
<p><input TYPE="button" value="彈出警告框" onCLICK="AlertButton()"></p>
</form>
<script language="javascript"><!--
function AlertButton(){window.alert("要多多光臨呀!");}
// --></script> 
26.狀態(tài)欄信息
<form>
<p><input TYPE="button" value="狀態(tài)欄信息" onCLICK="StatusButton()"></p>
</form>
<script language="javascript"><!--
function StatusButton(){window.status="要多多光臨呀!";}
// --></script> 
27.背景色變換
<form>
<p><input TYPE="button" value="背景色變換" onClick="BgButton()"></p>
</form>
<script>function BgButton(){
if (document.bgColor=='#00ffff')
{document.bgColor='#ffffff';}
else{document.bgColor='#00ffff';}
}
</script> 
28.點(diǎn)擊打開新窗口
<form>
<p><input TYPE="button" value="打開新窗口" onCLICK="NewWindow()"></p>
</form>
<script language="javascript"><!--
function NewWindow(){window.open("http://www.mcmx.com";;,"","height=240,width=340,status=no,location=no,toolbar=no,directories=no,menubar=no");}
// --></script></body>
29.分頁(yè)代碼:
<%''本程序文件名為:Pages.asp%>
<%''包含ADO常量表文件adovbs.inc,可從"\Program Files\Common Files\System\ADO"目錄下拷貝%>
<!--#Include File="adovbs.inc"-->
<%''*建立數(shù)據(jù)庫(kù)連接,這里是Oracle8.05數(shù)據(jù)庫(kù)
Set conn = Server.CreateObject("ADODB.Connection")
conn.Open "Provider=msdaora.1;Data Source=YourSrcName;User ID=YourUserID;Password=YourPassword;"  
Set rs = Server.CreateObject("ADODB.Recordset") ''創(chuàng)建Recordset對(duì)象
rs.CursorLocation = adUseClient ''設(shè)定記錄集指針屬性
''*設(shè)定一頁(yè)內(nèi)的記錄總數(shù),可根據(jù)需要進(jìn)行調(diào)整
rs.PageSize = 10  
''*設(shè)置查詢語(yǔ)句
StrSQL = "Select ID,姓名,住址,電話 from 通訊錄 order By ID"
rs.Open StrSQL, conn, adOpenStatic, adLockReadOnly, adCmdText
%>
<HTML>
<HEAD>
<title>分頁(yè)示例</title>
<script language=javascript>
//點(diǎn)擊"[第一頁(yè)]"時(shí)響應(yīng):
function PageFirst()
{
document.MyForm.CurrentPage.selectedIndex=0;
document.MyForm.CurrentPage.onchange();
}
//點(diǎn)擊"[上一頁(yè)]"時(shí)響應(yīng):
function PagePrior()
{
document.MyForm.CurrentPage.selectedIndex--;
document.MyForm.CurrentPage.onchange();
}
//點(diǎn)擊"[下一頁(yè)]"時(shí)響應(yīng):
function PageNext()
{
document.MyForm.CurrentPage.selectedIndex++;
document.MyForm.CurrentPage.onchange();
}
//點(diǎn)擊"[最后一頁(yè)]"時(shí)響應(yīng):
function PageLast()
{
document.MyForm.CurrentPage.selectedIndex=document.MyForm.CurrentPage.length-1;
document.MyForm.CurrentPage.onchange();
}
//選擇"第?頁(yè)"時(shí)響應(yīng):
function PageCurrent()
{ //Pages.asp是本程序的文件名
document.MyForm.action='Pages.asp?Page='+(document.MyForm.CurrentPage.selectedIndex+1)
document.MyForm.submit();
}
</Script>
</HEAD>
<BODY bgcolor="#ffffcc" link="#008000" vlink="#008000" alink="#FF0000""> 
<%
If rs.EOF Then
    Response.Write("<font size=2 color=#000080>[數(shù)據(jù)庫(kù)中沒有記錄!]</font>")
Else
    ''指定當(dāng)前頁(yè)碼
    If Request("CurrentPage") = "" Then
        rs.AbsolutePage = 1
    Else
        rs.AbsolutePage = CLng(Request("CurrentPage"))
    End If  
    ''創(chuàng)建表單MyForm,方法為Get
    Response.Write("<form method=Get name=MyForm>")
    Response.Write("<p align=center><font size=2 color=#008000>")
    ''設(shè)置翻頁(yè)超鏈接
    If rs.PageCount = 1 Then
        Response.Write("[第一頁(yè)] [上一頁(yè)] [下一頁(yè)] [最后一頁(yè)] ")
    Else
        If rs.AbsolutePage = 1 Then
            Response.Write("[第一頁(yè)] [上一頁(yè)] ")
            Response.Write("[<a href=java script:PageNext()>下一頁(yè)</a>] ")
            Response.Write("[<a href=java script:PageLast()>最后一頁(yè)</a>] ")
        Else
            If rs.AbsolutePage = rs.PageCount Then
                Response.Write("[<a href=java script:PageFirst()>第一頁(yè)</a>] ")
                Response.Write("[<a href=java script:PagePrior()>上一頁(yè)</a>] ")
                Response.Write("[下一頁(yè)] [最后一頁(yè)] ")
            Else
                Response.Write("[<a href=java script:PageFirst()>第一頁(yè)</a>] ")
                Response.Write("[<a href=java script:PagePrior()>上一頁(yè)</a>] ")
                Response.Write("[<a href=java script:PageNext()>下一頁(yè)</a>] ")
                Response.Write("[<a href=java script:PageLast()>最后一頁(yè)</a>] ")
            End If
        End If
    End If 
    ''創(chuàng)建下拉列表框,用于選擇瀏覽頁(yè)碼
    Response.Write("第<select size=1 name=CurrentPage onchange=PageCurrent()>")
    For i = 1 To rs.PageCount
        If rs.AbsolutePage = i Then
            Response.Write("<option selected>"&i&"</option>") ''當(dāng)前頁(yè)碼
        Else
            Response.Write("<option>"&i&"</option>")
        End If
    Next
    Response.Write("</select>頁(yè)/共"&rs.PageCount&"頁(yè) 共"&rs.RecordCount&"條記錄</font><p>")
    Response.Write("</form>") 
    ''創(chuàng)建表格,用于顯示
    Response.Write("<table align=center cellspacing=1 cellpadding=1 border=1")
    Response.Write(" bordercolor=#99CCFF bordercolordark=#b0e0e6 bordercolorlight=#000066>") 
    Response.Write("<tr bgcolor=#ccccff bordercolor=#000066>")  
    Set Columns = rs.Fields  
    ''顯示表頭
    For i = 0 To Columns.Count -1
        Response.Write("<td align=center width=200 height=13>")
        Response.Write("<font size=2><b>"&Columns(i).Name&"</b></font></td>")
    Next
    Response.Write("</tr>")
    ''顯示內(nèi)容
    For i = 1 To rs.PageSize
        Response.Write("<tr bgcolor=#99ccff bordercolor=#000066>")
        For j = 0 To Columns.Count -1
            Response.Write("<td><font size=2>"&Columns(j)&"</font></td>")
        Next
        Response.Write("</tr>") 
        rs.movenext
        If rs.EOF Then Exit For
        Next 
        Response.Write("</table>")  
    End If
%>
</BODY>
</HTML>
<%
Rem - - - 表單提示函數(shù) Being - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
CODE Copy ...

Function Check_submit(Str, restr)
    If Str = "" Then
        response.Write "<script>"
        response.Write "alert(‘'"&restr&"‘');"
        response.Write "history.go(-1)"
        response.Write "</script>"
        response.End
    Else
        Check_submit = Str
    End If
End Function


CODE Copy ...

Function Alert_submit(Str)
    response.Write "<script>"
    response.Write "alert(‘'"&Str&"‘');"
    ‘'response.Write "location.reload();"
    response.Write "</script>"
End Function


CODE Copy ...

Function localhost_submit(Str, urls)
    response.Write "<script>"
    If Str<>"" Then
        response.Write "alert(‘'"&Str&"‘');"
    End If
    response.Write "location=‘'"&urls&"‘';"
    response.Write "</script>"
End Function


Rem - - - 生成自定義位隨機(jī)數(shù) Being - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
CODE Copy ...

Function makerndid(byVal maxLen)
    Dim strNewPass
    Dim whatsNext, upper, lower, intCounter
    Randomize
    For intCounter = 1 To maxLen
        whatsNext = Int(2 * Rnd)
        If whatsNext = 0 Then
            upper = 80
            lower = 70
        Else
            upper = 48
            lower = 39
        End If
        strNewPass = strNewPass & Chr(Int((upper - lower + 1) * Rnd + upper))
    Next
    makerndid = strNewPass
End Function


Rem - - - 生成四位隨機(jī)數(shù) Being - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
CODE Copy ...

Function get_rand()
    Dim num1
    Dim rndnum
    Randomize
    Do While Len(rndnum)<4
        num1 = CStr(Chr((57 -48) * Rnd + 48))
        rndnum = rndnum&num1
    Loop
    get_rand = rndnum
End Function


Rem - - - 判斷數(shù)據(jù)是否整型 Being - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
CODE Copy ...

Function IsInteger(para)
    On Error Resume Next
    Dim Str
    Dim l, i
    If IsNull(para) Then
        isInteger = False
        Exit Function
    End If
    Str = CStr(para)
    If Trim(Str) = "" Then
        isInteger = False
        Exit Function
    End If
    l = Len(Str)
    For i = 1 To l
        If Mid(Str, i, 1)>"9" or Mid(Str, i, 1)<"0" Then
            isInteger = False
            Exit Function
        End If
    Next
    isInteger = True
    If Err.Number<>0 Then Err.Clear
End Function


Rem - - - 數(shù)據(jù)庫(kù)鏈接函數(shù) Being - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
CODE Copy ...

Function OpenCONN
    Set conn = Server.CreateObject("ADODB.Connection")
    connstr = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & Server.MapPath(DB_login)
    conn.Open connstr
End Function


Rem - - - 中文字符轉(zhuǎn)Uncode代碼函數(shù) Being - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
CODE Copy ...

Function URLEncoding(vstrIn)
    strReturn = ""
    For i = 1 To Len(vstrIn)
        ThisChr = Mid(vStrIn, i, 1)
        If Abs(Asc(ThisChr)) < &HFF Then
            strReturn = strReturn & ThisChr
        Else
            innerCode = Asc(ThisChr)
            If innerCode < 0 Then
                innerCode = innerCode + &H10000
            End If
            Hight8 = (innerCode And &HFF00) \ &HFF
            Low8 = innerCode And &HFF
            strReturn = strReturn & "%" & Hex(Hight8) & "%" & Hex(Low8)
        End If
    Next
    URLEncoding = strReturn
End Function


Rem - - - Html過(guò)濾函數(shù) Being - - - - - - - - - - - - - - - - - - - - - - - - - - - - - Function Htmlout(Str)
CODE Copy ...
Dim result
Dim l
If IsNull(Str) Then
    Htmlout = ""
    Exit Function
End If
l = Len(Str)
result = ""
Dim i
For i = 1 To l
    Select Case Mid(Str, i, 1)
        Case "<"
            result = result + "&lt;"
        Case ">"
            result = result + "&gt;"
        Case Chr(13)
            If session("admin_system") = "" Then
                result = result + "<br>"
            End If
        Case Chr(34)
            result = result + "&quot;"
        Case "&"
            result = result + "&amp;"
        Case Chr(32)
            ‘'result = result + "&nbsp;"
            If i + 1<= l And i -1>0 Then
                If Mid(Str, i + 1, 1) = Chr(32) or Mid(Str, i + 1, 1) = Chr(9) or Mid(Str, i -1, 1) = Chr(32) or Mid(Str, i -1, 1) = Chr(9) Then
                    result = result + "&nbsp;"
                Else
                    result = result + " "
                End If
            Else
                result = result + "&nbsp;"
            End If
        Case Chr(9)
            result = result + " "
        Case Else
            result = result + Mid(Str, i, 1)
    End Select
Next
Htmlout = result
End Function


Rem - - - textarea顯示用 - - -
CODE Copy ...

Function htmlencode1(fString)
    If fString<>"" And Not IsNull(fString) Then
        fString = Replace(fString, "&gt;", ">")
        fString = Replace(fString, "&lt;", "<")
        fString = Replace(fString, "&nbsp;", Chr(32))
        fString = Replace(fString, "</p><p>", Chr(10) & Chr(10))
        fString = Replace(fString, "<br>", Chr(10))
        htmlencode1 = fString
    Else
        htmlencode1 = ""
    End If
End Function


Rem - - - 頁(yè)面顯示用 - - -
CODE Copy ...

Function htmlencode2(fString)
    If fString<>"" And Not IsNull(fString) Then
        fString = Replace(fString, ">", "&gt;")
        fString = Replace(fString, "<", "&lt;")
        fString = Replace(fString, Chr(32), "&nbsp;")
        fString = Replace(fString, Chr(10) & Chr(10), "</p><p>")
        fString = Replace(fString, Chr(10), "<br>")
        htmlencode2 = fString
    Else
        htmlencode2 = ""
    End If
End Function


Rem - - - 取出指定字符串前后的字符串方法 - - -
CODE Copy ...

Function GetStrs(str1, CharFlag, Dflag)
    Dim tmpstr
    If Dflag = 0 Then‘'取左
    pos1 = InStr(str1, charFlag)
    If pos1<= 20 Then
        tmpstr = Left(str1, pos1 -1)
    Else
        tmpstr = Mid(str1, pos1 -20, 20)
    End If
Else ‘'取右
    pos1 = InStr(str1, charFlag) + Len(charFlag)
    If Len(str1) - pos1<= 20 Then
        tmpstr = Right(str1, Len(str1) - pos1)
    Else
        tmpstr = Mid(str1, pos1 + 1, 20)
    End If
End If
GetStrs = tmpstr
End Function


Rem - - - 取出文件名 - - -
CODE Copy ...

Function GetFileName(Str)
    pos = InStr(Str, ".")
    If Str<>"" Then
        Str = Mid(Str, pos, Len(Str))
    End If
    GetFileName = Str
End Function


Rem - - - 取到瀏覽器版本轉(zhuǎn)換字符串 - - -
CODE Copy ...

Function browser()
    Dim text
    text = Request.ServerVariables("HTTP_USER_AGENT")
    If InStr(text, "MSIE 5.5")>0 Then
        browser = "IE 5.5"
    ElseIf InStr(text, "MSIE 6.0")>0 Then
        browser = "IE 6.0"
    ElseIf InStr(text, "MSIE 5.01")>0 Then
        browser = "IE 5.01"
    ElseIf InStr(text, "MSIE 5.0")>0 Then
        browser = "IE 5.00"
    ElseIf InStr(text, "MSIE 4.0")>0 Then
        browser = "IE 4.01"
    Else
        browser = "未知"
    End If
End Function


Rem - - - 取到系統(tǒng)腳本轉(zhuǎn)換字符串 - - -
CODE Copy ...

Function System(text)
    If InStr(text, "NT 5.1")>0 Then
        System = System + "Windows XP"
    ElseIf InStr(text, "NT 5")>0 Then
        System = System + "Windows 2000"
    ElseIf InStr(text, "NT 4")>0 Then
        System = System + "Windows NT4"
    ElseIf InStr(text, "4.9")>0 Then
        System = System + "Windows ME"
    ElseIf InStr(text, "98")>0 Then
        System = System + "Windows 98"
    ElseIf InStr(text, "95")>0 Then
        System = System + "Windows 95"
    Else
        System = System + "未知"
    End If
End Function


Rem - - - = 刪除文件 - - -
CODE Copy ...

Function delfile(filepath)
    imangepath = Trim(filepath)
    Path = server.MapPath(imangepath)
    Set fs = server.CreateObject("Scripting.FileSystemObject")
    If FS.FileExists(Path) Then
        FS.DeleteFile(Path)
    End If
    Set fs = Nothing
End Function


Rem - - - 得到真實(shí)的客戶端IP - - -
CODE Copy ...

Public Function GetClientIP()
    Dim uIpAddr
    ‘' 本函數(shù)參考webcn.Net / AspHouse 文獻(xiàn)<取真實(shí)的客戶IP>
    uIpAddr = Request.ServerVariables("HTTP_X_FORWARDED_FOR")
    If uIpAddr = "" Then uIpAddr = Request.ServerVariables("REMOTE_ADDR")
    GetClientIP = uIpAddr
    uIpAddr = ""
End Function


%>

數(shù)據(jù)庫(kù)查詢中的特殊字符的問(wèn)題
在進(jìn)行數(shù)據(jù)庫(kù)的查詢時(shí),會(huì)經(jīng)常遇到這樣的情況:
  例如想在一個(gè)用戶數(shù)據(jù)庫(kù)中查詢他的用戶名和他的密碼,但恰好該用戶使用的名字和密碼中有特殊的字符,例如單引號(hào),“|”號(hào),雙引號(hào)或者連字符“&”。
  例如他的名字是1"test,密碼是A|&900
  這時(shí)當(dāng)你執(zhí)行以下的查詢語(yǔ)句時(shí),肯定會(huì)報(bào)錯(cuò):
SQL = "Select * FROM SecurityLevel Where UID="" & UserID & """
SQL = SQL & " AND PWD="" & Password & """
  因?yàn)槟愕腟QL將會(huì)是這樣:
Select * FROM SecurityLevel Where UID="1"test" AND PWD="A|&900"
  在SQL中,"|"為分割字段用的,顯然會(huì)出錯(cuò)了。現(xiàn)在提供下面的幾個(gè)函數(shù) 專門用來(lái)處理這些頭疼的東西:
Quoted from Unkown:
<%
Function ReplaceStr (TextIn, ByVal SearchStr As String, _
                     ByVal Replacement As String, _
                     ByVal CompMode As Integer)


     Dim WorkText As String, Pointer As Integer
     If IsNull(TextIn) Then
      ReplaceStr = Null
     Else
      WorkText = TextIn
      Pointer = InStr(1, WorkText, SearchStr, CompMode)
      Do While Pointer > 0
       WorkText = Left(WorkText, Pointer - 1) & Replacement & _
                        Mid(WorkText, Pointer + Len(SearchStr))
       Pointer = InStr(Pointer + Len(Replacement), WorkText, SearchStr, CompMode)
      Loop
      ReplaceStr = WorkText
     End If
End Function


Function SQLFixup(TextIn)
     SQLFixup = ReplaceStr(TextIn, """, """", 0)
End Function


Function JetSQLFixup(TextIn)
     Dim Temp
     Temp = ReplaceStr(TextIn, """, """", 0)
     JetSQLFixup = ReplaceStr(Temp, "|", "" & Chr(124) & "", 0)
End Function


Function FindFirstFixup(TextIn)
     Dim Temp
     Temp = ReplaceStr(TextIn, """, "" & chr(39) & "", 0)
     FindFirstFixup = ReplaceStr(Temp, "|", "" & Chr(124) & "", 0)
End Function

Rem 借助RecordSet將二進(jìn)制流轉(zhuǎn)化成文本
Quoted from Unkown:

Function BinaryToString(biData, Size)
    Const adLongVarChar = 201
    Set RS = CreateObject("ADODB.Recordset")
    RS.Fields.Append "mBinary", adLongVarChar, Size
    RS.Open
    RS.AddNew
    RS("mBinary").AppendChunk(biData)
    RS.Update
    BinaryToString = RS("mBinary").Value
    RS.Close
End Function

%>
<%
'定義超全局變量
Dim URLSelf, URISelf
URISelf = Request.ServerVariables("SCRIPT_NAME")
If Request.QueryString = "" Then
    URLSelf = URISelf
Else
    URLSelf = URISelf & "?" & Request.QueryString
End If
Response.CharSet = "GB2312"
Response.Buffer = True
Response.Expires = -1


'===================================================================================
' 函數(shù)原型:GotoURL (URL)
'功能:轉(zhuǎn)到指定的URL
'參數(shù):URL 要跳轉(zhuǎn)的URL
'返 回 值:無(wú)
'涉及的表:無(wú)
'===================================================================================

Public Function GotoURL(URL)
    Response.Write "<script language=""JavaScript"">location.href='" & URL & "';</script>"
End Function

'===================================================================================
' 函數(shù)原型:MessageBox (Msg)
'功能:顯示消息框
'參數(shù):要顯示的消息
'返 回 值:無(wú)
'涉及的表:無(wú)
'===================================================================================

Public Function MessageBox(msg)
    msg = Replace(msg, "\", "\\")
    msg = Replace(msg, "'", "\'")
    msg = Replace(msg, """", "\""")
    msg = Replace(msg, vbCrLf, "\n")
    msg = Replace(msg, vbCr, "")
    msg = Replace(msg, vbLf, "")
    Response.Write "<script language=""JavaScript"">alert('" & msg & "');</script>"
End Function

'===================================================================================
' 函數(shù)原型:ReturnValue (bolValue)
'功能:設(shè)置Window對(duì)象的返回值:只能是布爾值
'參數(shù):返回值
'返 回 值:無(wú)
'涉及的表:無(wú)
'===================================================================================

Public Function ReturnValue(bolValue)
    If bolValue Then
        Response.Write "<script language=""JavaScript"">window.returnValue=true;</script>"
    Else
        Response.Write "<script language=""JavaScript"">window.returnValue=false;</script>"
    End If
End Function

'===================================================================================
' 函數(shù)原型:GoBack (URL)
'功能:后退
'參數(shù):無(wú)
'返 回 值:無(wú)
'涉及的表:無(wú)
'===================================================================================

Public Function GoBack()
    Response.Write "<script language=""JavaScript"">history.go(-1);</script>"
End Function

'===================================================================================
' 函數(shù)原型:CloseWindow ()
'功能:關(guān)閉窗口
'參數(shù):無(wú)
'返 回 值:無(wú)
'涉及的表:無(wú)
'===================================================================================

Public Function CloseWindow()
    Response.Write "<script language=""JavaScript"">window.opener=null;window.close();</script>"
End Function

'===================================================================================
' 函數(shù)原型:RefreshParent ()
'功能:刷新父框架
'參數(shù):無(wú)
'返 回 值:無(wú)
'涉及的表:無(wú)
'===================================================================================

Public Function RefreshParent()
    Response.Write "<script language=""JavaScript"">if(parent!=self) parent.location.reload();</script>"
End Function

'===================================================================================
' 函數(shù)原型:RefreshTop ()
'功能:刷新頂級(jí)框架
'參數(shù):無(wú)
'返 回 值:無(wú)
'涉及的表:無(wú)
'===================================================================================

Public Function RefreshTop()
    Response.Write "<script language=""JavaScript"">if(top!=self) top.location.reload();</script>"
End Function

'===================================================================================
' 函數(shù)原型:GenPassword (intLen,PassMask)
'功能:生成隨機(jī)密碼
'參數(shù):intLen新密碼長(zhǎng)度
'PassMask生成密碼的掩碼默認(rèn)為空
'返 回 值:無(wú)
'涉及的表:無(wú)
'===================================================================================

Public Function GenPassword(intLen, PassMask)
    Dim iCnt, PosTemp
    Randomize
    If PassMask = "" Then
        PassMask = "ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789abcdefghijklmnopqrstuvwxyz"
    End If
    For iCnt = 1 To intLen
        PosTemp = Fix(Rnd(1) * (Len(PassMask))) + 1
        GenPassword = GenPassword & Mid(PassMask, PosTemp, 1)
    Next
End Function

'===================================================================================
' 函數(shù)原型:GenSerialString ()
'功能:生成序列號(hào)
'參數(shù):無(wú)
'返 回 值:無(wú)
'涉及的表:無(wú)
'===================================================================================

Public Function GenSerialString()
    GenSerialString = Year(Now())
    If Month(Now())<10 Then
        GenSerialString = GenSerialString & "0"
    End If
    GenSerialString = GenSerialString & Month(Now())
    If Day(Now())<10 Then
        GenSerialString = GenSerialString & "0"
    End If
    GenSerialString = GenSerialString & Day(Now())
    If Hour(Now())<10 Then
        GenSerialString = GenSerialString & "0"
    End If
    GenSerialString = GenSerialString & Hour(Now())
    If Minute(Now())<10 Then
        GenSerialString = GenSerialString & "0"
    End If
    GenSerialString = GenSerialString & Minute(Now())
    If Second(Now())<10 Then
        GenSerialString = GenSerialString & "0"
    End If
    GenSerialString = GenSerialString & Second(Now())
    GenSerialString = GenSerialString & GenPassword(6, "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ")
End Function


'===================================================================================
' 函數(shù)原型:ChangePage(URLTemplete,PageIndex)
'功能:根據(jù)URL模板生成新的頁(yè)面URL
'參數(shù):URLTempleteURL模板
' PageIndex新的頁(yè)碼
'返 回 值:生成的URL
'涉及的表:無(wú)
'===================================================================================

Public Function ChangePage(URLTemplete, PageIndex)
    ChangePage = SetQueryString(URLTemplete, "PAGE", PageIndex)
End Function

'===================================================================================
' 函數(shù)原型:BuildPath(sPath)
'功能:根據(jù)指定的路徑創(chuàng)建目錄
'參數(shù):sPathURL模板
'返 回 值:如果成功,返回空字符串,否則返回錯(cuò)誤信息和錯(cuò)誤位置
'涉及的表:無(wú)
'===================================================================================

Public Function BuildPath (sPath)
    Dim iCnt
    Dim Path
    Dim BasePath
    Path = Split(sPath, "/")
    If Left(sPath, 1) = "/" or Left(sPath, 1) = "\" Then
        BasePath = Server.MapPath("/")
    Else
        BasePath = Server.MapPath(".")
    End If
    Dim cPath, oFso
    cPath = BasePath
    BuildPath = ""
    Set oFso = Server.CreateObject("Scripting.FileSystemObject")
    For iCnt = LBound(Path) To UBound(Path)
        If Trim(Path(iCnt))<>"" Then
            cPath = cPath & "\" & Trim(Path(iCnt))
            If Not oFso.FolderExists(cPath) Then
                On Error Resume Next
                oFso.CreateFolder cPath
                If Err.Number<>0 Then
                    BuildPath = Err.Description & "[" & cPath & "]"
                    Exit For
                End If
                On Error GoTo 0
            End If
        End If
    Next
    Set oFso = Nothing
End Function

'===================================================================================
' 函數(shù)原型:GetUserAgentInfo(ByRef vSoft,ByRef vOs)
'功能:獲取客戶端操作系統(tǒng)和瀏覽器信息
'參數(shù):vSoft瀏覽器信息
'vOs操作系統(tǒng)信息
'返 回 值:無(wú)
'涉及的表:無(wú)
'===================================================================================

Public Function GetUserAgentInfo(ByRef vSoft, ByRef vOs)
    Dim theSoft
    theSoft = Request.ServerVariables("HTTP_USER_AGENT")
    ' 瀏覽器
    If InStr(theSoft, "NetCaptor") Then
        vSoft = "NetCaptor"
    ElseIf InStr(theSoft, "MSIE 6") Then
        vSoft = "MSIE 6.0"
    ElseIf InStr(theSoft, "MSIE 5.5+") Then
        vSoft = "MSIE 5.5"
    ElseIf InStr(theSoft, "MSIE 5") Then
        vSoft = "MSIE 5.0"
    ElseIf InStr(theSoft, "MSIE 4") Then
        vSoft = "MSIE 4.0"
    ElseIf InStr(theSoft, "Netscape") Then
        vSoft = "Netscape"
    ElseIf InStr(theSoft, "Opera") Then
        vSoft = "Opera"
    Else
        vSoft = "Other"
    End If
    ' 操作系統(tǒng)
    If InStr(theSoft, "Windows NT 5.0") Then
        vOs = "Windows 2000"
    ElseIf InStr(theSoft, "Windows NT 5.1") Then
        vOs = "Windows XP"
    ElseIf InStr(theSoft, "Windows NT 5.2") Then
        vOs = "Windows 2003"
    ElseIf InStr(theSoft, "Windows NT") Then
        vOs = "Windows NT"
    ElseIf InStr(theSoft, "Windows 9") Then
        vOs = "Windows 9x"
    ElseIf InStr(theSoft, "unix") Then
        vOs = "Unix"
    ElseIf InStr(theSoft, "linux") Then
        vOs = "Linux"
    ElseIf InStr(theSoft, "SunOS") Then
        vOs = "SunOS"
    ElseIf InStr(theSoft, "BSD") Then
        vOs = "BSD"
    ElseIf InStr(theSoft, "Mac") Then
        vOs = "Mac"
    Else
        vOs = "Other"
    End If
End Function

'===================================================================================
' 函數(shù)原型:GetRegexpObject()
'功能:獲得一個(gè)正則表達(dá)式對(duì)象
'參數(shù):無(wú)
'返 回 值:正則表達(dá)式對(duì)象
'涉及的表:無(wú)
'===================================================================================

Public Function GetRegExpObject(sPattern)
    Dim r
    Set r = New RegExp
    r.Global = True
    r.IgnoreCase = True
    r.MultiLine = True
    r.Pattern = sPattern
    Set GetRegexpObject = r
    Set r = Nothing
End Function

'===================================================================================
' 函數(shù)原型:RegExpTest(pattern,string)
'功能:正則表達(dá)式檢測(cè)
'參數(shù):pattern模式字符串
'string待檢查的字符串
'返 回 值:是否匹配
'涉及的表:無(wú)
'===================================================================================

Public Function RegExpTest(p, s)
    Dim r
    Set r = GetRegExpObject(p)
    RegExpTest = r.Test(s)
    Set r = Nothing
End Function

'===================================================================================

' 函數(shù)原型:RegExpReplace(sSource,sPattern,sRep)
'功能:正則表達(dá)式替換
'參數(shù):sSource要替換的源字符串
'sPattern模式字符串
'sRep要替換的目標(biāo)字符串
'返 回 值:替換后的字符串
'涉及的表:無(wú)
'===================================================================================

Public Function RegExpReplace(sSource, sPattern, sRep)
    Dim r
    Set r = GetRegExpTest(sPattern)
    RegExpReplace = r.Replace(sSource, sRep)
    Set r = Nothing
End Function

'===================================================================================
' 函數(shù)原型:CreateXMLParser()
'功能:創(chuàng)建一個(gè)盡可能高版本的XMLDOM
'參數(shù):無(wú)
'返 回 值:IDOMDocument對(duì)象
'涉及的表:無(wú)
'===================================================================================

Public Function CreateXMLParser()
    On Error Resume Next
    Set CreateXMLParser = Server.CreateObject("MSXML2.DOMDocument.4.0")
    If Err.Number<>0 Then
        Err.Clear
        Set CreateXMLParser = Server.CreateObject("MSXML2.DOMDocument.3.0")
        If Err.Number<>0 Then
            Err.Clear
            Set CreateXMLParser = Server.CreateObject("MSXML2.DOMDocument.2.6")
            If Err.Number<>0 Then
                Err.Clear
                Set CreateXMLParser = Server.CreateObject("MSXML2.DOMDocument")
                If Err.Number<>0 Then
                    Err.Clear
                    Set CreateXMLParser = Server.CreateObject("Microsoft.XMLDOM")
                    If Err.Number<>0 Then
                        Err.Clear
                        Set CreateXMLParser = Nothing
                    Else
                        Exit Function
                    End If
                Else
                    Exit Function
                End If
            Else
                Exit Function
            End If
        Else
            Exit Function
        End If
    Else
        Exit Function
    End If
    On Error GoTo 0
End Function


'===================================================================================
' 函數(shù)原型:CreateHTTPPoster()
'功能:創(chuàng)建一個(gè)盡可能高版本的XMLHTTP
'參數(shù):ServerOrClient創(chuàng)建ServerXMLHTTP還是XMLHTTP
'返 回 值:IXMLHTTP對(duì)象
'涉及的表:無(wú)
'===================================================================================

Public Function CreateHTTPPoster(soc)
    Dim s
    If soc Then
        s = "ServerXMLHTTP"
    Else
        s = "XMLHTTP"
    End If
    On Error Resume Next
    Set CreateHTTPPoster = Server.CreateObject("MSXML2." & s & ".4.0")
    If Err.Number<>0 Then
        Err.Clear
        Set CreateHTTPPoster = Server.CreateObject("MSXML2." & s & ".3.0")
        If Err.Number<>0 Then
            Err.Clear
            Set CreateHTTPPoster = Server.CreateObject("MSXML2." & s)
            If Err.Number<>0 Then
                Set CreateHTTPPoster = Nothing
            Else
                Exit Function
            End If
        Else
            Exit Function
        End If
    Else
        Exit Function
    End If
    On Error GoTo 0
End Function

'===================================================================================
' 函數(shù)原型:XMLThrowError (errCode,errReason)
'功能:拋出一個(gè)XML錯(cuò)誤消息
'參數(shù):errCode錯(cuò)誤編碼
'errReason錯(cuò)誤原因
'返 回 值:無(wú)
'涉及的表:無(wú)
'===================================================================================

Public Sub XMLThrowError (errCode, errReason)
    Response.Clear
    Response.ContentType = "text/xml"
    Response.Write"<?xml version=""1.0"" encoding=""gb2312"" standalone=""yes"" ?>" & vbCrLf & _
        "<ERROR CODE=""" & errCode & """ REASON=""" & errReason & """ />" & vbCrLf
    Response.Flush
    Response.End
End Sub

'===================================================================================
' 函數(shù)原型:GetXMLNodeValue(ByRef xmlDom,sFilter,sDefValue)
'功能:從一個(gè)XML文檔中查找指定節(jié)點(diǎn)的值
'參數(shù):xmlDomXML文檔
'sFilterXPATH定位字符串
'sDefValue默認(rèn)值
'返 回 值:無(wú)
'涉及的表:無(wú)
'===================================================================================

Public Function GetXMLNodeValue(ByRef xmlDom, sFilter, sDefValue)
    Dim oNode
    Set oNode = xmlDom.selectSingleNode(sFilter)
    If TypeName(oNode) = "Nothing" or TypeName(oNode) = "Null" or TypeName(oNode) = "Empty" Then
        GetXMLNodeValue = sDefValue
        Set oNode = Nothing
    Else
        GetXMLNodeValue = Trim(oNode.Text)
        Set oNode = Nothing
    End If
End Function

'===================================================================================
' 函數(shù)原型:GetXMLNodeAttribute(ByRef xmlDom,sFilter,sName,sDefValue)
'功能:從一個(gè)XML文檔中查找指定節(jié)點(diǎn)的指定屬性
'參數(shù):xmlDomXML文檔
'sFilterXPATH定位字符串
'sName要查詢的屬性名稱
'sDefValue默認(rèn)值
'返 回 值:無(wú)
'涉及的表:無(wú)
'===================================================================================

Public Function GetXMLNodeAttribute(ByRef xmlDom, sFilter, sName, sDefValue)
    Dim oNode
    Set oNode = xmlDom.selectSingleNode(sFilter)
    If TypeName(oNode) = "Nothing" or TypeName(oNode) = "Null" or TypeName(oNode) = "Empty" Then
        GetXMLNodeAttribute = sDefValue
        Set oNode = Nothing
    Else
        Dim pTemp
        Set pTemp = oNode.getAttribute(sName)
        If TypeName(pTemp) = "Nothing" or TypeName(pTemp) = "Null" or TypeName(pTemp) = "Empty" Then
            GetXMLNodeAttribute = sDefValue
            Set oNode = Nothing
            Set pTemp = Nothing
        Else
            GetXMLNodeAttribute = Trim(pTemp.Value)
            Set oNode = Nothing
            Set pTemp = Nothing
        End If
    End If
End Function

'===================================================================================
' 函數(shù)原型:GetQueryStringNumber (FieldName,defValue)
'功能:從QueryString獲取一個(gè)整數(shù)
'參數(shù):FieldName參數(shù)名
'defValue默認(rèn)值
'返 回 值:無(wú)
'涉及的表:無(wú)
'===================================================================================

Public Function GetQueryStringNumber (FieldName, defValue)
    Dim r
    r = Request.QueryString(FieldName)
    If r = "" Then
        GetQueryStringNumber = defValue
        Exit Function
    Else
        If Not IsNumeric(r) Then
            GetQueryStringNumber = defValue
            Exit Function
        Else
            On Error Resume Next
            r = CDbl(r)
            If Err.Number<>0 Then
                Err.Clear
                GetQueryStringNumber = defValue
                Exit Function
            Else
                GetQueryStringNumber = r
            End If
            On Error GoTo 0
        End If
    End If
End Function

'===================================================================================
' 函數(shù)原型:I(yíng)If (testExpr,value1,value2)
'功能:相當(dāng)于C/C++里面的 ?: 運(yùn)算符
'參數(shù):testExprBoolean表達(dá)式
'value1testExpr=True 時(shí)的取值
'value2testExpr=False 時(shí)的取值
'返 回 值:如果testExpr為True返回value1否則返回value2
'涉及的表:無(wú)
'說(shuō)明:VBScript里沒有Iif函數(shù)
'===================================================================================

Public Function IIf(testExpr, value1, value2)
    If testExpr = True Then
        IIf = value1
    Else
        IIf = value2
    End If
End Function


'===================================================================================
' 函數(shù)原型:URLEncoding (v,f)
'功能:URL編碼函數(shù)
'參數(shù):v中英文混合字符串
'f是否對(duì)ASCII字符編碼
'返 回 值:編碼后的ASC字符串
'涉及的表:無(wú)
'===================================================================================

Public Function URLEncoding(v, f)
    Dim s, t, i, j, h, l, x
    s = ""
    x = Len(v)
    For i = 1 To x
        t = Mid(v, i, 1)
        j = Asc(t)
        If j> 0 Then
            If f Then
                s = s & "%" & Right("00" & Hex(Asc(t)), 2)
            Else
                s = s & t
            End If
        Else
            If j < 0 Then j = j + &H10000
            h = (j And &HFF00) \ &HFF
            l = j And &HFF
            s = s & "%" & Hex(h) & "%" & Hex(l)
        End If
    Next
    URLEncoding = s
End Function

'===================================================================================
' 函數(shù)原型:URLDecoding (sIn)
'功能:URL解碼碼函數(shù)
'參數(shù):vURL編碼的字符串
'返 回 值:解碼后的字符串
'涉及的表:無(wú)
'===================================================================================

Public Function URLDecoding(Sin)
    Dim s, i, l, c, t, n
    s = ""
    l = Len(Sin)
    For i = 1 To l
        c = Mid(Sin, i, 1)
        If c<>"%" Then
            s = s & c
        Else
            c = Mid(Sin, i + 1, 2)
            i = i + 2
            t = CInt("&H" & c)
            If t<&H80 Then
                s = s & Chr(t)
            Else
                c = Mid(Sin, i + 1, 3)
                If Left(c, 1)<>"%" Then
                    URLDecoding = s
                    Exit Function
                Else
                    c = Right(c, 2)
                    n = CInt("&H" & c)
                    t = t * 256 + n -65536
                    s = s & Chr(t)
                    i = i + 3
                End If
            End If
        End If
    Next
    URLDecoding = s
End Function

'===================================================================================
' 函數(shù)原型:Bytes2BSTR (v)
'功能:UTF-8編碼轉(zhuǎn)換到正常的GB2312
'參數(shù):vUTF-8編碼字節(jié)流
'返 回 值:解碼后的字符串
'涉及的表:無(wú)
'===================================================================================

Public Function Bytes2BSTR(v)
    Dim r, i, t, n
    r = ""
    For i = 1 To LenB(v)
        t = AscB(MidB(v, i, 1))
        If t < &H80 Then
            r = r & Chr(t)
        Else
            n = AscB(MidB(v, i + 1, 1))
            r = r & Chr(CLng(t) * &H100 + CInt(n))
            i = i + 1
        End If
    Next
    Bytes2BSTR = r
End Function
%>

相關(guān)文章

最新評(píng)論

亚洲免费在线视频网站| 日韩美女精品视频在线观看网站| 亚洲国产成人在线一区| 一区二区在线观看少妇| av天堂中文免费在线| 骚货自慰被发现爆操| 日日夜夜精品一二三| 日韩亚洲高清在线观看| 亚洲国产美女一区二区三区软件| 99re久久这里都是精品视频| 欧美成人精品欧美一级黄色| 在线免费91激情四射 | 久久久噜噜噜久久熟女av| 日美女屁股黄邑视频| 扒开腿挺进肉嫩小18禁视频| 中文字幕av第1页中文字幕| 色综合天天综合网国产成人| 久久精品亚洲国产av香蕉| 中文字幕第三十八页久久| 97精品视频在线观看| 91精品国产高清自在线看香蕉网 | 亚洲推理片免费看网站| 国产精品视频欧美一区二区| 91精品高清一区二区三区| 98视频精品在线观看| 一区二区免费高清黄色视频| 天天日天天干天天插舔舔| 伊人成人综合开心网| 在线免费观看av日韩| 天天日天天天天天天天天天天| 欧美80老妇人性视频| 天天通天天透天天插| 国产刺激激情美女网站| 久久精品亚洲国产av香蕉| 福利午夜视频在线观看| 日韩人妻xxxxx| 999热精品视频在线| 在线免费观看日本伦理| 五十路熟女人妻一区二区9933| 大香蕉玖玖一区2区| 日韩欧美一级精品在线观看| 亚洲精品高清自拍av| 91国产资源在线视频| 女同互舔一区二区三区| 在线视频自拍第三页| 亚洲福利午夜久久久精品电影网| 久久精品国产23696| 久久久久久久一区二区三| 青青草视频手机免费在线观看| v888av在线观看视频| 粉嫩av懂色av蜜臀av| 中文字幕中文字幕 亚洲国产| 欧美日韩国产一区二区三区三州 | 亚洲va国产va欧美va在线| 国产三级片久久久久久久| 夜夜骑夜夜操夜夜奸| 成人综合亚洲欧美一区 | 最新国产亚洲精品中文在线| 影音先锋女人av噜噜色| 中文字幕在线乱码一区二区| 国产麻豆乱子伦午夜视频观看| 人人妻人人爽人人澡人人精品| 97超碰国语国产97超碰| 欧美80老妇人性视频| 国产男女视频在线播放| 欧美美女人体视频一区| 国产成人精品久久二区91| 2021国产一区二区| 啪啪啪操人视频在线播放| 亚洲综合自拍视频一区| 91麻豆精品传媒国产黄色片| 和邻居少妇愉情中文字幕| 欧美偷拍亚洲一区二区| 中文字幕一区二区三区蜜月| 91人妻精品久久久久久久网站 | 硬鸡巴动态操女人逼视频| 日韩人妻丝袜中文字幕| 视频一区二区三区高清在线| 国产高清精品一区二区三区| 色婷婷久久久久swag精品| 白嫩白嫩美女极品国产在线观看| 韩国爱爱视频中文字幕| 第一福利视频在线观看| 国产三级影院在线观看| 绝色少妇高潮3在线观看| 任我爽精品视频在线播放| 国产超码片内射在线| 美女福利写真在线观看视频| 80电影天堂网官网| 久草视频在线一区二区三区资源站| 护士小嫩嫩又紧又爽20p| 日本一道二三区视频久久| 青春草视频在线免费播放| 啊啊好大好爽啊啊操我啊啊视频 | 日视频免费在线观看| 精品一区二区三区三区色爱| 亚洲 人妻 激情 中文| 888欧美视频在线| 丝袜长腿第一页在线| 韩国女主播精品视频网站| 人妻丰满熟妇综合网| 精品一线二线三线日本| 国产V亚洲V天堂无码欠欠| 久久久久久久99精品| 欧美日本aⅴ免费视频| 国产成人一区二区三区电影网站| 亚洲1区2区3区精华液| 鸡巴操逼一级黄色气| 不卡日韩av在线观看| 777奇米久久精品一区| 99热碰碰热精品a中文| 国产在线免费观看成人| 精品av国产一区二区三区四区| 国产97在线视频观看| 亚洲欧美福利在线观看| 亚洲精品午夜aaa久久| 久久精品国产23696| 中文字幕中文字幕人妻| 91麻豆精品久久久久| 男女啪啪啪啪啪的网站| 婷婷色国产黑丝少妇勾搭AV | 最新国产亚洲精品中文在线| 午夜毛片不卡免费观看视频| 93人妻人人揉人人澡人人| 国产刺激激情美女网站| 免费人成黄页网站在线观看国产 | 色伦色伦777国产精品| 久久久久五月天丁香社区| 国产使劲操在线播放| 日韩av有码中文字幕| 国产第一美女一区二区三区四区 | av天堂资源最新版在线看| 青青青青青手机视频| 阴茎插到阴道里面的视频| 少妇人妻100系列| 亚洲 欧美 自拍 偷拍 在线| 2019av在线视频| 青青青青草手机在线视频免费看| 久久丁香花五月天色婷婷| 精品91高清在线观看| 欧美美女人体视频一区| 91九色porny蝌蚪国产成人| 女警官打开双腿沦为性奴| 黄色片一级美女黄色片| av森泽佳奈在线观看| 97人妻无码AV碰碰视频| 91p0rny九色露脸熟女| 2021最新热播中文字幕| 亚洲综合另类精品小说| 黑人大几巴狂插日本少妇| 欧美激情电影免费在线| 国产97视频在线精品| 午夜极品美女福利视频| 干逼又爽又黄又免费的视频| 蜜桃臀av蜜桃臀av| 天天草天天色天天干| 国产一区二区欧美三区| 亚洲欧美综合在线探花| 黑人解禁人妻叶爱071| 日本中文字幕一二区视频| 成年午夜影片国产片| 日韩欧美高清免费在线| 亚洲福利精品福利精品福利| 日本五十路熟新垣里子| 五十路熟女av天堂| 国产三级精品三级在线不卡| 日韩成人综艺在线播放| 国产精品人久久久久久| 国产精品系列在线观看一区二区| 91自产国产精品视频| 水蜜桃一区二区三区在线观看视频| 青青青青青青青在线播放视频 | 可以在线观看的av中文字幕| 日韩av有码一区二区三区4| 97精品视频在线观看| 欧美伊人久久大香线蕉综合| 午夜精品福利一区二区三区p| 最新欧美一二三视频| 天堂av中文在线最新版| 91国内视频在线观看| 香蕉91一区二区三区| 午夜蜜桃一区二区三区| 小泽玛利亚视频在线观看| 精品av久久久久久久| 桃色视频在线观看一区二区| 老师让我插进去69AV| 国产一区二区久久久裸臀| 人妻丰满熟妇综合网| 中文字幕在线乱码一区二区| av中文在线天堂精品| 天美传媒mv视频在线观看| 国产成人小视频在线观看无遮挡| 亚洲1卡2卡三卡4卡在线观看 | 久久艹在线观看视频| 亚洲高清国产自产av| 日本高清在线不卡一区二区 | 天天干天天爱天天色| 国产精品一区二区三区蜜臀av| 国产欧美日韩在线观看不卡| 免费看高清av的网站| 在线免费观看亚洲精品电影| yellow在线播放av啊啊啊| 欧美xxx成人在线| 中文字幕av第1页中文字幕| 亚国产成人精品久久久| 天天干夜夜操啊啊啊| 18禁网站一区二区三区四区| 国产女人被做到高潮免费视频| 传媒在线播放国产精品一区| 天天日天天干天天要| 国产精品自偷自拍啪啪啪| 色吉吉影音天天干天天操| 美女被肏内射视频网站| 在线视频这里只有精品自拍| 欧美在线偷拍视频免费看| 天天操夜夜操天天操天天操| 人妻丝袜诱惑我操她视频| 国产三级片久久久久久久| 色综合久久五月色婷婷综合| 成人国产影院在线观看| 欧美乱妇无乱码一区二区| 欧美久久久久久三级网| 国产女人露脸高潮对白视频| 男人天堂最新地址av| 午夜精品一区二区三区更新| 亚洲综合自拍视频一区| 激情图片日韩欧美人妻| 欧美亚洲自偷自拍 在线| 国产精品三级三级三级| 黄色三级网站免费下载| 精品少妇一二三视频在线| 青娱乐极品视频青青草| 中文字幕高清免费在线人妻| 日本韩国亚洲综合日韩欧美国产| 又粗又长 明星操逼小视频 | 狍和女人的王色毛片| 亚洲高清视频在线不卡| 国产 在线 免费 精品| 亚洲国产成人在线一区| 亚洲国产在人线放午夜| 国产白嫩美女一区二区| 91www一区二区三区| 麻豆性色视频在线观看| 狠狠鲁狠狠操天天晚上干干| 97人人妻人人澡人人爽人人精品| 美女 午夜 在线视频| 亚洲精品国产久久久久久| 美女吃鸡巴操逼高潮视频| 青青擦在线视频国产在线| 免费男阳茎伸入女阳道视频| 欧美乱妇无乱码一区二区| 老师啊太大了啊啊啊尻视频| 中文字幕熟女人妻久久久| 内射久久久久综合网| 欧美日韩在线精品一区二区三| 欧美中国日韩久久精品| av天堂中文免费在线| 午夜大尺度无码福利视频 | 国产高潮无码喷水AV片在线观看| 日本www中文字幕| 人妻少妇精品久久久久久| 国产精品成人xxxx| 91九色porny国产蝌蚪视频| 国产超码片内射在线| 国产成人精品一区在线观看| 中文字幕在线欧美精品| 亚洲欧美激情人妻偷拍| 在线播放国产黄色av| 久久久久久性虐视频| 欧美视频不卡一区四区| 蜜臀av久久久久久久| 激情人妻校园春色亚洲欧美| 美女 午夜 在线视频| 国产污污污污网站在线| 99av国产精品欲麻豆| 97色视频在线观看| 国产性色生活片毛片春晓精品| 熟女妇女老妇一二三区| 偷拍自拍福利视频在线观看| 欧美精产国品一二三产品区别大吗| 日本熟妇喷水xxx| 亚洲美女美妇久久字幕组| 人妻自拍视频中国大陆| 天堂av狠狠操蜜桃| 亚洲视频在线观看高清| 日韩特级黄片高清在线看| 国产视频一区二区午夜| 亚洲欧美一区二区三区电影| 亚洲成人线上免费视频观看| 天天操夜夜骑日日摸| 青青草国内在线视频精选| 国产精品大陆在线2019不卡| 丝袜长腿第一页在线| 亚洲一区二区三区精品视频在线| 一区二区三区四区五区性感视频| 欧美一级色视频美日韩| 中文字幕一区二区自拍| 亚洲精品 欧美日韩| 美女被肏内射视频网站| aⅴ五十路av熟女中出| 特黄老太婆aa毛毛片| 欧美黑人与人妻精品| 三上悠亚和黑人665番号| 国产白袜脚足J棉袜在线观看| 97超碰免费在线视频| 久久精品亚洲国产av香蕉| 亚洲av日韩高清hd| 丰满少妇翘臀后进式| 欧美偷拍亚洲一区二区| 青青草原色片网站在线观看| 久久精品亚洲成在人线a| 亚洲最大黄 嗯色 操 啊| 中文字幕乱码人妻电影| 熟女在线视频一区二区三区| 久久丁香花五月天色婷婷| 啊啊啊想要被插进去视频| 在线观看国产免费麻豆| 视频一区二区综合精品| 99亚洲美女一区二区三区| 大屁股肉感人妻中文字幕在线| 大香蕉玖玖一区2区| 久久久久只精品国产三级| 一级A一级a爰片免费免会员 | 阿v天堂2014 一区亚洲| 又粗又硬又猛又黄免费30| 超级福利视频在线观看| 欧美地区一二三专区| 黑人借宿ntr人妻的沦陷2| 偷青青国产精品青青在线观看| 4个黑人操素人视频网站精品91 | 伊人综合免费在线视频| 亚洲男人在线天堂网| 99久久久无码国产精品性出奶水| 欧美日本在线观看一区二区| 福利片区一区二体验区| 啪啪啪18禁一区二区三区| 在线视频自拍第三页| 欧美黑人巨大性xxxxx猛交| 丝袜肉丝一区二区三区四区在线看| av无限看熟女人妻另类av| av中文字幕网址在线| 国产精品入口麻豆啊啊啊| 天天摸天天干天天操科普| 亚洲人一区二区中文字幕| 国产精品成人xxxx| 亚洲色偷偷综合亚洲AV伊人| 欧美精品黑人性xxxx| 三上悠亚和黑人665番号| 骚货自慰被发现爆操| 成熟熟女国产精品一区| 57pao国产一区二区| 国产av国片精品一区二区| 18禁美女羞羞免费网站| 蜜桃视频在线欧美一区| 人妻少妇一区二区三区蜜桃| 91国产资源在线视频| 超pen在线观看视频公开97| 最新中文字幕免费视频| 亚洲成人激情视频免费观看了 | 欧美日韩v中文在线| 99热色原网这里只有精品| 老司机午夜精品视频资源| 亚洲天天干 夜夜操| 喷水视频在线观看这里只有精品 | 欧亚乱色一区二区三区| 99热久久这里只有精品8| 欧美亚洲一二三区蜜臀| 国产V亚洲V天堂无码欠欠| 中文字幕午夜免费福利视频| 亚洲狠狠婷婷综合久久app| 这里有精品成人国产99| 女同性ⅹxx女同h偷拍| av无限看熟女人妻另类av| 中文人妻AV久久人妻水| 欧美精品一区二区三区xxxx| 18禁无翼鸟成人在线| 福利在线视频网址导航| 搡老妇人老女人老熟女| 久久一区二区三区人妻欧美| 国产亚洲视频在线二区| 亚洲 欧美 精品 激情 偷拍| 免费大片在线观看视频网站| 日本a级视频老女人| rct470中文字幕在线| 中文字幕一区二区三区蜜月| 农村胖女人操逼视频| 美女张开两腿让男人桶av| av完全免费在线观看av| 97超碰人人搞人人| 国产精品入口麻豆啊啊啊| 又黄又刺激的午夜小视频| 51国产成人精品视频| 任你操视频免费在线观看| 成人性爱在线看四区| 和邻居少妇愉情中文字幕| 日本成人一区二区不卡免费在线| 成人蜜桃美臀九一一区二区三区| 国产高潮无码喷水AV片在线观看| 国产九色91在线视频| 亚洲伊人久久精品影院一美女洗澡| 中国熟女一区二区性xx| 精品久久久久久久久久中文蒉| av在线播放国产不卡| 亚洲国产在线精品国偷产拍| 欧美特色aaa大片| 亚洲 清纯 国产com| 亚洲另类图片蜜臀av| 国产一区二区久久久裸臀| 少妇被强干到高潮视频在线观看| 黑人解禁人妻叶爱071| asmr福利视频在线观看| 性欧美日本大妈母与子| 色秀欧美视频第一页| 亚洲国产精品久久久久蜜桃| 欧美国产亚洲中英文字幕| 人妻素人精油按摩中出| 久草视频在线看免费| 黄片三级三级三级在线观看| 亚洲天堂成人在线观看视频网站| 一个人免费在线观看ww视频| 9国产精品久久久久老师 | 丝袜亚洲另类欧美变态| 大鸡巴操b视频在线| 亚洲1069综合男同| 亚洲推理片免费看网站| 五十路老熟女码av| av破解版在线观看| 最新日韩av传媒在线| 欧美精品欧美极品欧美视频 | 一区二区三区久久久91| 亚洲成人激情视频免费观看了| 5528327男人天堂| 91人妻精品一区二区在线看| 91精品国产91青青碰| av老司机精品在线观看| 亚洲嫩模一区二区三区| 午夜在线精品偷拍一区二| 91she九色精品国产| 2021天天色天天干| 国产一线二线三线的区别在哪| 久久丁香婷婷六月天| 一区二区三区蜜臀在线| 精品久久久久久久久久久99| av中文在线天堂精品| 天堂av中文在线最新版| 777奇米久久精品一区| 国产精品一区二区久久久av| 偷拍自拍 中文字幕| 硬鸡巴动态操女人逼视频| 特大黑人巨大xxxx| 亚洲美女自偷自拍11页| 扒开让我视频在线观看| 93精品视频在线观看| 人妻少妇亚洲精品中文字幕| 亚洲欧美精品综合图片小说| 亚洲国产在人线放午夜| 无码日韩人妻精品久久| 99精品视频之69精品视频 | 国产 在线 免费 精品| 狍和女人的王色毛片| 国产黄网站在线观看播放| 亚洲精品国产久久久久久| 97a片免费在线观看| 国产白袜脚足J棉袜在线观看| 日本韩国免费一区二区三区视频| 新婚人妻聚会被中出| 亚洲第17页国产精品| 91人妻人人做人人爽在线| 欧美性受xx黑人性猛交| 激情五月婷婷免费视频| 偷青青国产精品青青在线观看 | 男人靠女人的逼视频| 免费在线观看视频啪啪| 91快播视频在线观看| 日本特级片中文字幕| 五十路熟女人妻一区二区9933| 五十路人妻熟女av一区二区| 性感美女福利视频网站| 2012中文字幕在线高清| 中文字母永久播放1区2区3区| 男人插女人视频网站| 欧美日本在线观看一区二区| 欧美精产国品一二三区| 成熟熟女国产精品一区| 国产97视频在线精品| 久草视频首页在线观看| yy96视频在线观看| 在线观看免费岛国av| 国产精品黄色的av| 一本久久精品一区二区| 亚洲成人午夜电影在线观看| 一区二区麻豆传媒黄片| 天天日天天鲁天天操| 欧美xxx成人在线| 青青青视频手机在线观看| 亚洲熟女综合色一区二区三区四区 | 亚洲av天堂在线播放| 激情国产小视频在线| 老司机免费福利视频网| 五月色婷婷综合开心网4438| 日本人妻少妇18—xx| 国产不卡av在线免费| 欧美专区日韩专区国产专区| 巨乳人妻日下部加奈被邻居中出| 91极品大一女神正在播放| 人人在线视频一区二区| 欧美日韩高清午夜蜜桃大香蕉| 欧美第一页在线免费观看视频| 色综合久久无码中文字幕波多| 久久www免费人成一看片| 久久久久久久99精品| 亚洲欧美一区二区三区爱爱动图| 11久久久久久久久久久| 日日夜夜狠狠干视频| 精品高跟鞋丝袜一区二区| 国产精品探花熟女在线观看| 国产露脸对白在线观看| 男人操女人的逼免费视频| 成人亚洲精品国产精品| 亚洲一区二区久久久人妻| 天天想要天天操天天干| 亚洲综合一区成人在线| 大陆胖女人与丈夫操b国语高清| 欧美一区二区三区在线资源| 天堂av狠狠操蜜桃| 九色视频在线观看免费| 日韩av有码中文字幕| 九九热99视频在线观看97| 特大黑人巨大xxxx| 2021天天色天天干| 中文字幕高清免费在线人妻 | 蜜桃视频在线欧美一区| 久久美欧人妻少妇一区二区三区| chinese国产盗摄一区二区| 国产麻豆国语对白露脸剧情 | 亚洲中文字字幕乱码| 成人福利视频免费在线| 3344免费偷拍视频| 亚洲国产欧美一区二区三区久久| 国产日本欧美亚洲精品视| 黄色视频成年人免费观看| 2021最新热播中文字幕| 国产+亚洲+欧美+另类| 日韩欧美一级黄片亚洲| 亚洲视频在线视频看视频在线| 色吉吉影音天天干天天操| 日本在线一区二区不卡视频| 一个色综合男人天堂| 日本一本午夜在线播放| 成人福利视频免费在线| 国产女人叫床高潮大片视频| 亚欧在线视频你懂的| 一区二区三区视频,福利一区二区| 亚洲另类在线免费观看| av在线免费中文字幕| 一二三中文乱码亚洲乱码one | 女生被男生插的视频网站| 一个人免费在线观看ww视频| 天天插天天狠天天操| 91九色国产熟女一区二区| 国产亚洲成人免费在线观看| 欧美视频不卡一区四区| 岛国一区二区三区视频在线| 欧美老妇精品另类不卡片| 久草视频在线一区二区三区资源站 | 黄片大全在线观看观看| 国产高清97在线观看视频| 91久久国产成人免费网站| 亚国产成人精品久久久| 大鸡吧插逼逼视频免费看 | 中文字幕午夜免费福利视频| 中文亚洲欧美日韩无线码| 色哟哟国产精品入口| 亚洲伊人色一综合网| 久久久噜噜噜久久熟女av| 亚洲av自拍偷拍综合| 搡老妇人老女人老熟女| 精品91自产拍在线观看一区| 免费岛国喷水视频在线观看| 天天操天天干天天艹| 日本少妇人妻xxxxxhd| 日韩av免费观看一区| v888av在线观看视频| 边摸边做超爽毛片18禁色戒| 污污小视频91在线观看| 1区2区3区4区视频在线观看| 男生舔女生逼逼的视频| 阴茎插到阴道里面的视频| 亚洲特黄aaaa片| 91人妻人人做人人爽在线| 1024久久国产精品| 国产午夜亚洲精品麻豆| 日本熟妇一区二区x x| 亚洲国产成人最新资源| 中文字幕日本人妻中出| 蜜桃色婷婷久久久福利在线| 99re国产在线精品| 欧美国品一二三产区区别| 亚洲特黄aaaa片| 91成人精品亚洲国产| 欧美精品 日韩国产| 75国产综合在线视频| 婷婷五月亚洲综合在线| 无码国产精品一区二区高潮久久4| 美女张开两腿让男人桶av| 国产一区二区神马久久| 国产成人自拍视频播放 | 亚洲av琪琪男人的天堂| 国产男女视频在线播放| 亚洲人妻视频在线网| 精品日产卡一卡二卡国色天香| 日韩av中文在线免费观看| 中英文字幕av一区| 久久h视频在线观看| av线天堂在线观看| 蜜桃精品久久久一区二区| 2022天天干天天操| 成年人该看的视频黄免费| 天天操天天操天天碰| 人人爱人人妻人人澡39| 欧美精品资源在线观看| 国产在线拍揄自揄视频网站| 国产成人精品一区在线观看| 91国产资源在线视频| 午夜毛片不卡免费观看视频| 亚洲激情av一区二区| 午夜大尺度无码福利视频 | 丝袜国产专区在线观看| 日本三极片视频网站观看| 香港一级特黄大片在线播放| 亚洲欧洲av天堂综合| 91国内精品久久久久精品一| av网址国产在线观看| 亚洲综合自拍视频一区| 1000部国产精品成人观看视频| 水蜜桃国产一区二区三区| 男女啪啪视频免费在线观看| 中文人妻AV久久人妻水| 国产在线观看黄色视频| 天天操天天干天天艹| 一区国内二区日韩三区欧美| 亚洲精品久久视频婷婷| 欧美xxx成人在线| 亚洲欧美另类自拍偷拍色图| 99国内小视频在现欢看| 精品日产卡一卡二卡国色天香| 日本女大学生的黄色小视频| 91免费放福利在线观看| 天天插天天狠天天操| 大香蕉玖玖一区2区| 精品91自产拍在线观看一区| 天天做天天干天天操天天射| 亚洲欧美综合另类13p| 大白屁股精品视频国产| 91超碰青青中文字幕| 黄色的网站在线免费看| 91快播视频在线观看| 中文字幕一区二区三区人妻大片 | www天堂在线久久| 久久这里只有精彩视频免费| 97精品成人一区二区三区| 国产精品3p和黑人大战| 国产刺激激情美女网站| 自拍偷拍一区二区三区图片| 青青尤物在线观看视频网站| 新婚人妻聚会被中出| 亚洲青青操骚货在线视频| 日韩一个色综合导航| 国产亚洲四十路五十路| 日本啪啪啪啪啪啪啪| 蜜桃久久久久久久人妻| 亚洲精品欧美日韩在线播放| 51国产成人精品视频| av在线观看网址av| 97精品人妻一区二区三区精品| 人人妻人人澡人人爽人人dvl| 黄页网视频在线免费观看| 水蜜桃一区二区三区在线观看视频 | 国产一区二区火爆视频| 青青青青青免费视频| 在线观看av2025| 久久精品国产23696| 国产免费av一区二区凹凸四季| 精品国产污污免费网站入口自| 日噜噜噜夜夜噜噜噜天天噜噜噜| 无套猛戳丰满少妇人妻| 日本精品美女在线观看| 中文字幕无码日韩专区免费| 人妻3p真实偷拍一二区| 成年人啪啪视频在线观看| 中文字幕一区二区三区人妻大片| 国产九色91在线观看精品| 中文字幕人妻被公上司喝醉在线| 91精品国产91久久自产久强 | 老司机欧美视频在线看| 亚洲中文字幕国产日韩| 开心 色 六月 婷婷| 免费在线看的黄网站| 天天日天天操天天摸天天舔| 欧美亚洲少妇福利视频| 亚洲乱码中文字幕在线| 日韩欧美在线观看不卡一区二区| 天天干天天爱天天色| 成人精品在线观看视频| 91九色porny国产蝌蚪视频| 免费成人av中文字幕| 国产日韩精品电影7777| 亚洲1卡2卡三卡4卡在线观看| 91桃色成人网络在线观看| h国产小视频福利在线观看| 97国产精品97久久| 亚洲免费va在线播放| weyvv5国产成人精品的视频| 亚洲熟妇无码一区二区三区| 精产国品久久一二三产区区别| 中文字幕 码 在线视频| av成人在线观看一区| 日本丰满熟妇BBXBBXHD| 男人插女人视频网站| 98精产国品一二三产区区别| 久久久久久9999久久久久| 97精品成人一区二区三区| 99精品国产aⅴ在线观看| 在线观看免费av网址大全| 国产a级毛久久久久精品| 国产又色又刺激在线视频| 天天综合天天综合天天网| 中文字幕奴隷色的舞台50| 亚洲成人国产综合一区| 中文字幕+中文字幕| 日本一二三区不卡无| 欧美黑人性猛交xxxxⅹooo| 日日夜夜精品一二三| 91天堂天天日天天操| 初美沙希中文字幕在线| 久草视频在线免播放| 在线新三级黄伊人网| 国产变态另类在线观看| 亚洲伊人av天堂有码在线| 3344免费偷拍视频| 99久久99久国产黄毛片| 自拍偷拍日韩欧美一区二区| 天天日夜夜操天天摸| 亚洲另类图片蜜臀av| 日日爽天天干夜夜操| 日本美女性生活一级片| 岛国免费大片在线观看| 最近的中文字幕在线mv视频| 熟妇一区二区三区高清版| 成人在线欧美日韩国产| 一区二区三区麻豆福利视频| v888av在线观看视频| 午夜蜜桃一区二区三区| 青青青青在线视频免费观看| 五十路老熟女码av| 免费av岛国天堂网站| 国产视频网站一区二区三区| 日本高清成人一区二区三区| 国产亚洲精品品视频在线| 国产麻豆剧传媒精品国产av蜜桃| 男女啪啪啪啪啪的网站| 欧美3p在线观看一区二区三区| 视频一区二区三区高清在线| 最近中文字幕国产在线| 亚洲综合一区二区精品久久| 天天射夜夜操狠狠干| 成人亚洲国产综合精品| 最新日韩av传媒在线| 亚洲综合图片20p| 美女福利写真在线观看视频| 午夜影院在线观看视频羞羞羞| 在线免费视频 自拍| 亚洲天堂有码中文字幕视频| 国产男女视频在线播放| 日韩av免费观看一区| 亚洲一区二区三区久久午夜| 午夜大尺度无码福利视频| 日日操夜夜撸天天干| 精品一线二线三线日本| 欲满人妻中文字幕在线| 国产在线观看黄色视频| 一区二区三区日韩久久| 91av精品视频在线| www骚国产精品视频| 男人的网址你懂的亚洲欧洲av| 亚洲国产最大av综合| 人人妻人人爱人人草| 国产1区,2区,3区| 久草福利电影在线观看| 中字幕人妻熟女人妻a62v网| 岛国毛片视频免费在线观看| 欧美成人综合视频一区二区| 亚洲一区二区三区av网站| 国产精彩福利精品视频| 78色精品一区二区三区| 欧美日韩亚洲国产无线码| 成人18禁网站在线播放| 在线免费观看av日韩| 日韩欧美制服诱惑一区在线| 午夜av一区二区三区| 最新97国产在线视频| 国产精品入口麻豆啊啊啊| 国产aⅴ一线在线观看| 在线免费观看视频一二区| 啊啊好慢点插舔我逼啊啊啊视频| 欧美日本在线观看一区二区| 又粗又长 明星操逼小视频| 天天插天天狠天天操| 天天干天天日天天干天天操| 欧美精品久久久久久影院| 国产乱子伦精品视频潮优女| 二区中出在线观看老师| 日韩美女精品视频在线观看网站 | 少妇露脸深喉口爆吞精| 99国内精品永久免费视频| 久久三久久三久久三久久| 国产成人一区二区三区电影网站| 91高清成人在线视频| 在线免费观看黄页视频| 激情色图一区二区三区| 成人蜜臀午夜久久一区| 91福利在线视频免费观看| 色偷偷伊人大杳蕉综合网| 99精品久久久久久久91蜜桃| 新97超碰在线观看| 99热这里只有国产精品6| 日韩在线中文字幕色| 色狠狠av线不卡香蕉一区二区 | 熟女妇女老妇一二三区| 国产精品欧美日韩区二区| 国产午夜无码福利在线看| 国产女孩喷水在线观看| 93人妻人人揉人人澡人人| 欧美美女人体视频一区| 狠狠鲁狠狠操天天晚上干干| 亚洲中文字幕校园春色| 亚洲人妻国产精品综合| 黄色录像鸡巴插进去| 人妻丝袜诱惑我操她视频| 国产精品久久9999| h国产小视频福利在线观看| 老司机福利精品免费视频一区二区 | 啊啊好大好爽啊啊操我啊啊视频| 丝袜美腿视频诱惑亚洲无| 91麻豆精品传媒国产黄色片| 三上悠亚和黑人665番号| 中国把吊插入阴蒂的视频| 欧美国产亚洲中英文字幕| 美洲精品一二三产区区别| 在线观看欧美黄片一区二区三区 | 91九色porny国产在线| 干逼又爽又黄又免费的视频| 国产揄拍高清国内精品对白| 亚洲无线观看国产高清在线| 夜夜骑夜夜操夜夜奸| 被大鸡吧操的好舒服视频免费| japanese日本熟妇另类| 中文乱理伦片在线观看| 偷拍自拍 中文字幕| 色av色婷婷人妻久久久精品高清| 黄色黄色黄片78在线| 啊啊好大好爽啊啊操我啊啊视频 | 亚洲图片欧美校园春色| 国产精品福利小视频a| 久久美欧人妻少妇一区二区三区| 蝴蝶伊人久久中文娱乐网| 综合激情网激情五月五月婷婷| 成人久久精品一区二区三区| 999热精品视频在线| 人妻少妇一区二区三区蜜桃| 亚洲美女高潮喷浆视频| 在线观看黄色成年人网站| 91久久综合男人天堂| 亚洲最大免费在线观看| 欧美80老妇人性视频| 日韩欧美在线观看不卡一区二区| 欧美 亚洲 另类综合| 亚洲区美熟妇久久久久| 天天射,天天操,天天说| 久久久久久cao我的性感人妻| 一区二区三区精品日本| 亚洲中文字幕校园春色| 精品国产午夜视频一区二区| 人妻少妇一区二区三区蜜桃| 三级av中文字幕在线观看| 日本丰满熟妇BBXBBXHD| 日本人妻欲求不满中文字幕| 日本熟妇一区二区x x| 免费观看国产综合视频| 干逼又爽又黄又免费的视频| 在线国产日韩欧美视频| 激情伦理欧美日韩中文字幕| 91色九色porny| 亚洲国产成人最新资源| 国产精品系列在线观看一区二区| 香港三日本三韩国三欧美三级| 88成人免费av网站| 亚洲国产精品中文字幕网站| 姐姐的朋友2在线观看中文字幕| 欧美黄色录像免费看的| 白嫩白嫩美女极品国产在线观看| 丝袜长腿第一页在线| 91快播视频在线观看| 国产精品久久久黄网站| 岛国毛片视频免费在线观看| 看一级特黄a大片日本片黑人| 国产精品一区二区av国| 成人资源在线观看免费官网| 久久免看30视频口爆视频| 久久精品视频一区二区三区四区| 欧美一级片免费在线成人观看| 丰满的继坶3中文在线观看| 91大屁股国产一区二区| 成人24小时免费视频| 黄色无码鸡吧操逼视频| 亚洲另类综合一区小说| 婷婷激情四射在线观看视频| 熟女人妻在线观看视频| 日本一二三区不卡无| 男人和女人激情视频| 日韩北条麻妃一区在线| 啪啪啪操人视频在线播放| 在线成人日韩av电影| 亚洲高清国产自产av| 精品一区二区三区在线观看| 青青青青青青青青青青草青青 | 国产一区成人在线观看视频| 大鸡巴操娇小玲珑的女孩逼| 漂亮 人妻被中出中文| 11久久久久久久久久久| 天天色天天操天天透| 欧美区一区二区三视频| 欧美日本在线观看一区二区 | 中文字幕 人妻精品| 18禁美女黄网站色大片下载| 亚洲国产免费av一区二区三区| 一区二区三区四区五区性感视频| 天天操夜夜骑日日摸| 99re久久这里都是精品视频| 天天日天天干天天爱| 色97视频在线播放| 男生舔女生逼逼视频| 国产高清精品一区二区三区| 天堂资源网av中文字幕| 班长撕开乳罩揉我胸好爽| 99久久中文字幕一本人| 色呦呦视频在线观看视频| 欧美一级片免费在线成人观看| 超碰中文字幕免费观看| 中文字幕免费福利视频6| 天天日天天透天天操| 国产白袜脚足J棉袜在线观看| 日本熟女精品一区二区三区| 精品国产乱码一区二区三区乱| 五十路av熟女松本翔子| 少妇系列一区二区三区视频| 欧美男人大鸡吧插女人视频| 欧美成人综合色在线噜噜| brazzers欧熟精品系列| 精品一区二区三区在线观看| 亚洲欧美国产麻豆综合| 三级av中文字幕在线观看| 日本精品美女在线观看| 亚洲 图片 欧美 图片| 天堂av中文在线最新版| 99re国产在线精品| 亚洲日本一区二区久久久精品| 欧美一区二区三区久久久aaa| 亚洲粉嫩av一区二区三区| 免费一级黄色av网站| 精品区一区二区三区四区人妻| 在线网站你懂得老司机| 久久久久久9999久久久久| 一区二区三区四区视频| 日韩欧美一级黄片亚洲| 亚洲精品久久综合久| 亚洲av色图18p| 色呦呦视频在线观看视频| 欧美日韩中文字幕欧美| yellow在线播放av啊啊啊| 亚洲成高清a人片在线观看| 亚洲另类图片蜜臀av| 欧美视频中文一区二区三区| 久碰精品少妇中文字幕av | 99热99这里精品6国产| 欧美日韩一区二区电影在线观看 | 97成人免费在线观看网站| 欧美男同性恋69视频| 日本高清成人一区二区三区| 亚洲变态另类色图天堂网| 1区2区3区4区视频在线观看| 91人妻精品一区二区久久| 免费在线观看视频啪啪| 天天躁日日躁狠狠躁躁欧美av| 91精品国产高清自在线看香蕉网| av天堂中文免费在线| jul—619中文字幕在线| 国产自拍在线观看成人| 精品美女久久久久久| 人妻爱爱 中文字幕| 99久久中文字幕一本人| 免费十精品十国产网站| 亚洲欧美精品综合图片小说| 日韩在线视频观看有码在线| 精品人妻一二三区久久| 久久久久国产成人精品亚洲午夜| 成年人午夜黄片视频资源| 操人妻嗷嗷叫视频一区二区| 亚洲一区二区三区在线高清| 精品美女久久久久久| caoporm超碰国产| av破解版在线观看| 亚洲特黄aaaa片| 三级av中文字幕在线观看| 欧美日本aⅴ免费视频| 亚洲欧美综合另类13p| 高潮视频在线快速观看国家快速 | 久久这里只有精彩视频免费| 中文字幕在线乱码一区二区| 操日韩美女视频在线免费看| 欧美精品国产综合久久| 男人操女人逼逼视频网站| 又黄又刺激的午夜小视频| 一区二区三区四区五区性感视频| 熟妇一区二区三区高清版| 91国产资源在线视频| 久草视频首页在线观看| av天堂加勒比在线| 国产精品三级三级三级| 久久久久久久精品老熟妇| 日本性感美女三级视频| 亚洲av天堂在线播放| 国产精品久久9999| 国语对白xxxx乱大交| 欲乱人妻少妇在线视频裸| 91精品国产91青青碰| tube69日本少妇| 小泽玛利亚视频在线观看| 国产亚洲天堂天天一区| 青青青视频手机在线观看| 午夜场射精嗯嗯啊啊视频| 色综合天天综合网国产成人| 成人av久久精品一区二区| 高清成人av一区三区| 天堂av中文在线最新版| 亚洲另类伦春色综合小| 天天日天天干天天要| 38av一区二区三区| 97超碰人人搞人人| 阿v天堂2014 一区亚洲| 99久久成人日韩欧美精品| 国产精品视频男人的天堂| 欧美在线精品一区二区三区视频| 黄色成年网站午夜在线观看| 国产精品久久9999| 日本高清撒尿pissing| 黄色成人在线中文字幕| 精品国产高潮中文字幕| 中文字幕无码日韩专区免费| 熟女国产一区亚洲中文字幕| 晚上一个人看操B片| 9国产精品久久久久老师| 人妻3p真实偷拍一二区| 人妻凌辱欧美丰满熟妇| 国产在线免费观看成人| 亚洲国产免费av一区二区三区 | 五十路熟女人妻一区二| 在线观看的a站 最新| 日本18禁久久久久久| 国产白嫩美女一区二区| 在线免费91激情四射| 干逼又爽又黄又免费的视频| 不卡一区一区三区在线| 欧美亚洲偷拍自拍色图| 亚洲av男人天堂久久| 天堂av在线播放免费| 最新中文字幕乱码在线| 日本熟女精品一区二区三区| 国产高清精品一区二区三区| 久久麻豆亚洲精品av| 国产亚洲欧美45p| 青青热久免费精品视频在线观看 | 精品国产午夜视频一区二区| 欧美日韩中文字幕欧美| 密臀av一区在线观看| 97成人免费在线观看网站| 最新中文字幕乱码在线| 啪啪啪啪啪啪啪啪啪啪黄色| 黄色av网站免费在线| 99精品国产免费久久| 亚洲av无码成人精品区辽| AV天堂一区二区免费试看| 天美传媒mv视频在线观看| 日本免费一级黄色录像| 欧美第一页在线免费观看视频| 99久久成人日韩欧美精品| 亚洲少妇高潮免费观看| 亚洲无码一区在线影院| 激情伦理欧美日韩中文字幕| 精品一区二区亚洲欧美| 顶级尤物粉嫩小尤物网站| 91p0rny九色露脸熟女| 欧美精品伦理三区四区| 午夜精品一区二区三区城中村| 中文字幕免费福利视频6| 在线观看的a站 最新| 91人妻精品一区二区久久| av完全免费在线观看av| 国产成人小视频在线观看无遮挡| 在线免费观看日本伦理| 初美沙希中文字幕在线| 免费一级特黄特色大片在线观看| 成人蜜臀午夜久久一区| 国产黑丝高跟鞋视频在线播放| 天天日天天透天天操| 涩爱综合久久五月蜜臀| 成年人中文字幕在线观看| 日韩a级精品一区二区| 含骚鸡巴玩逼逼视频| avjpm亚洲伊人久久| 人妻3p真实偷拍一二区| 人人妻人人澡人人爽人人dvl| 性色蜜臀av一区二区三区| 中文字幕在线一区精品| 三级等保密码要求条款| 成人国产小视频在线观看| 日本一区二区三区免费小视频| 精品美女在线观看视频在线观看| 自拍偷拍日韩欧美亚洲| 欧美精品 日韩国产| 国内自拍第一页在线观看| 欧美成人黄片一区二区三区| 香蕉片在线观看av| 亚洲另类综合一区小说| 国产普通话插插视频| 爱有来生高清在线中文字幕| 国产av福利网址大全| 后入美女人妻高清在线| 国产欧美精品免费观看视频| 在线网站你懂得老司机| 天天插天天狠天天操| 久久久久久97三级| 国产清纯美女al在线| 欧美成人黄片一区二区三区| 日日操夜夜撸天天干| caoporm超碰国产| 91天堂天天日天天操| 被大鸡吧操的好舒服视频免费| 成人色综合中文字幕| 超碰97人人做人人爱| 国产高清精品极品美女| 国产免费av一区二区凹凸四季| 欧美精产国品一二三产品价格| 日本福利午夜电影在线观看| 性色蜜臀av一区二区三区| 亚洲一区二区三区久久受| 亚洲欧美人精品高清| 欧美黑人与人妻精品| 操人妻嗷嗷叫视频一区二区| 日本性感美女三级视频| 在线观看911精品国产| 91破解版永久免费| 亚洲人妻av毛片在线| 初美沙希中文字幕在线| 国产一区二区欧美三区| 婷婷六月天中文字幕| 中国黄色av一级片| 在线播放一区二区三区Av无码| 欧美日韩熟女一区二区三区| 精内国产乱码久久久久久| 久久一区二区三区人妻欧美| 日韩近亲视频在线观看| 亚洲一级 片内射视正片| 狠狠鲁狠狠操天天晚上干干| 亚洲少妇高潮免费观看| 天天艹天天干天天操| 亚洲av日韩精品久久久| 天堂va蜜桃一区入口| 国产午夜男女爽爽爽爽爽视频| 精品国产在线手机在线| 国产精品久久9999| 大尺度激情四射网站| 精品一区二区三区在线观看| 亚洲人妻国产精品综合| 91精品视频在线观看免费| 青草久久视频在线观看| 激情内射在线免费观看| 鸡巴操逼一级黄色气| 狠狠鲁狠狠操天天晚上干干| 日本三极片视频网站观看| 91快播视频在线观看| 亚洲欧美色一区二区| 特黄老太婆aa毛毛片| 日韩亚洲高清在线观看| 只有精品亚洲视频在线观看| 国产精品福利小视频a| rct470中文字幕在线| 国产欧美精品不卡在线| 中文字幕视频一区二区在线观看| 黑人3p华裔熟女普通话| 久久久91蜜桃精品ad| 又粗又硬又猛又黄免费30| 亚洲va欧美va人人爽3p| 国产一级精品综合av| 蜜桃久久久久久久人妻| 老司机你懂得福利视频| 久久丁香婷婷六月天| 午夜av一区二区三区 | 粉嫩欧美美人妻小视频| 超级福利视频在线观看| 91精品一区二区三区站长推荐| 国产午夜福利av导航| 国产V亚洲V天堂无码欠欠| 亚洲精品av在线观看| 51国产成人精品视频| 99re久久这里都是精品视频| 日本裸体熟妇区二区欧美| 伊人综合aⅴ在线网| 天天日天天干天天舔天天射| 天天日天天玩天天摸| 日韩a级黄色小视频| 99热国产精品666| 色伦色伦777国产精品| 亚洲国产欧美一区二区三区…| 亚洲天堂成人在线观看视频网站| 好了av中文字幕在线| 亚洲偷自拍高清视频| wwwxxx一级黄色片| 欧美 亚洲 另类综合| 夜夜嗨av一区二区三区中文字幕| 国产亚洲欧美视频网站| 一区二区三区久久久91| av资源中文字幕在线观看| 午夜久久久久久久99| 91老师蜜桃臀大屁股| 国产a级毛久久久久精品| weyvv5国产成人精品的视频| 可以免费看的www视频你懂的| 偷拍美女一区二区三区| 午夜91一区二区三区| 亚洲综合另类精品小说| 日本一区精品视频在线观看| 国产三级片久久久久久久| 欧美久久一区二区伊人| 免费在线观看污污视频网站| 蜜臀成人av在线播放| 成年美女黄网站18禁久久| 天天干天天操天天爽天天摸| 人妻素人精油按摩中出| 国产精品欧美日韩区二区| 亚洲高清免费在线观看视频| 国产精品视频一区在线播放| 亚洲av日韩精品久久久久久hd| 亚洲va国产va欧美va在线| 99精品国产自在现线观看| 欧美在线一二三视频| 青娱乐最新视频在线| 久久精品国产999| 欧美女同性恋免费a| 国产av欧美精品高潮网站| 日本熟妇色熟妇在线观看| 亚洲av日韩精品久久久| 免费人成黄页网站在线观看国产 | 欧美精品中文字幕久久二区| 天天色天天爱天天爽| 好男人视频在线免费观看网站| 亚洲国产精品中文字幕网站| 国产污污污污网站在线| 黄色成年网站午夜在线观看| 亚洲精品成人网久久久久久小说| 涩涩的视频在线观看视频| 国产精品一二三不卡带免费视频 | 中文字幕AV在线免费看 | 青青草视频手机免费在线观看| jul—619中文字幕在线| 51国产成人精品视频| 在线 中文字幕 一区| 又色又爽又黄的美女裸体| 欧美日韩熟女一区二区三区| 精品一区二区三区欧美| 91试看福利一分钟| 夜夜操,天天操,狠狠操| 欧美成人黄片一区二区三区| 绯色av蜜臀vs少妇| 国产性感美女福利视频| 国产黄网站在线观看播放| 制服丝袜在线人妻中文字幕| 亚洲精品在线资源站| 日本又色又爽又黄又粗| 免费手机黄页网址大全| 日本黄色特一级视频| 日本高清在线不卡一区二区| 国产又粗又硬又猛的毛片视频| 亚洲av日韩av网站| 日本www中文字幕| 青青擦在线视频国产在线| 一区二区熟女人妻视频| 亚洲天天干 夜夜操| 黄色片黄色片wyaa| 五十路老熟女码av| 1区2区3区不卡视频| 久草视频中文字幕在线观看| 一区二区三区蜜臀在线| 啪啪啪操人视频在线播放| 自拍偷拍日韩欧美一区二区| 欧美黑人性暴力猛交喷水| 色婷婷综合激情五月免费观看 | 亚洲美女高潮喷浆视频| 最新97国产在线视频| 国产内射中出在线观看| 中文字幕在线观看国产片| 把腿张开让我插进去视频| 亚洲精品无码色午夜福利理论片| gogo国模私拍视频| 国产视频一区在线观看| 久久免费看少妇高潮完整版| 日韩精品中文字幕福利| 老鸭窝在线观看一区| 久久久精品999精品日本| 18禁污污污app下载| 91色网站免费在线观看| 国产欧美精品不卡在线| 欧美成人一二三在线网| 欧美老鸡巴日小嫩逼| 开心 色 六月 婷婷| 成人蜜桃美臀九一一区二区三区| 老司机你懂得福利视频| 香港三日本三韩国三欧美三级| 人妻少妇性色欲欧美日韩| 五月精品丁香久久久久福利社| 中文字幕+中文字幕| 国产精品视频资源在线播放| 丝袜亚洲另类欧美变态| 亚洲av色图18p| 人人妻人人澡人人爽人人dvl| 国产之丝袜脚在线一区二区三区 | 免费观看国产综合视频| 日日操综合成人av| 亚洲熟妇无码一区二区三区| 特大黑人巨大xxxx| 9色精品视频在线观看| 青青青青在线视频免费观看| 欧美成人精品欧美一级黄色| 一级a看免费观看网站| 四川乱子伦视频国产vip| 天天干天天爱天天色| 日本熟妇喷水xxx| 日本阿v视频在线免费观看| 国产精品免费不卡av| 日本高清在线不卡一区二区| 在线免费视频 自拍| 五十路老熟女码av| 午夜av一区二区三区| 护士特殊服务久久久久久久| 一个色综合男人天堂| 888亚洲欧美国产va在线播放| 99热国产精品666| 亚洲欧美一区二区三区电影| 91精品资源免费观看| 日韩伦理短片在线观看| 啪啪啪啪啪啪啪免费视频| 天天操夜夜骑日日摸| 天天操,天天干,天天射| 亚洲va国产va欧美精品88| 成年人中文字幕在线观看| 福利视频网久久91| 97人妻色免费视频| 人妻素人精油按摩中出| 狍和女人的王色毛片| 亚洲欧美另类手机在线| 午夜久久久久久久精品熟女| 亚洲成a人片777777| 亚洲一区二区人妻av| 婷婷综合蜜桃av在线| 特黄老太婆aa毛毛片| 青青青青青手机视频| 久久久久久九九99精品| 国产老熟女伦老熟妇ⅹ| 亚洲福利天堂久久久久久| 亚洲国产精品久久久久久6| 不卡一区一区三区在线| 2o22av在线视频| 中国把吊插入阴蒂的视频| 岳太深了紧紧的中文字幕| 亚洲国产免费av一区二区三区| 岛国av高清在线成人在线| 又粗又长 明星操逼小视频 | 性感美女福利视频网站| 精品人妻伦一二三区久| 久久久精品999精品日本| 插逼视频双插洞国产操逼插洞| 欧美精品中文字幕久久二区| 另类av十亚洲av| 中文字幕乱码人妻电影| 天天躁夜夜躁日日躁a麻豆| 亚洲人成精品久久久久久久| 欧美精品欧美极品欧美视频| 人妻熟女在线一区二区| 2022国产综合在线干| 玩弄人妻熟妇性色av少妇| 久久久久久久99精品| 亚洲福利午夜久久久精品电影网| 人妻少妇亚洲精品中文字幕| 日韩精品电影亚洲一区| 婷婷综合蜜桃av在线| 亚洲av一妻不如妾| 精品美女久久久久久| 亚洲最大黄了色网站| 中国把吊插入阴蒂的视频| 日韩美女精品视频在线观看网站| 1000部国产精品成人观看视频| 天堂中文字幕翔田av| 国产九色91在线观看精品| 4个黑人操素人视频网站精品91| 亚洲精品麻豆免费在线观看 | 91she九色精品国产| 91九色国产熟女一区二区| 粉嫩小穴流水视频在线观看| 玖玖一区二区在线观看| 欧美视频不卡一区四区| 久久热这里这里只有精品| 亚洲 中文 自拍 另类 欧美| 国产精品精品精品999| 亚洲成人激情av在线| 国产日韩精品电影7777| 亚洲男人让女人爽的视频| 国产精品视频资源在线播放 | 久久综合老鸭窝色综合久久| 午夜成午夜成年片在线观看| 久草视频福利在线首页| 丰满熟女午夜福利视频| 欧洲亚洲欧美日韩综合| 欧亚乱色一区二区三区| 久久久91蜜桃精品ad| 国产在线91观看免费观看| 制丝袜业一区二区三区| 视频在线免费观看你懂得| 狠狠操操操操操操操操操| 国产一线二线三线的区别在哪| 国产av福利网址大全| 不戴胸罩引我诱的隔壁的人妻| 大香蕉大香蕉在线有码 av| 天天躁日日躁狠狠躁av麻豆| 午夜精品福利91av| 91精品综合久久久久3d动漫| 亚洲天天干 夜夜操| 888欧美视频在线| 最新日韩av传媒在线| 日本特级片中文字幕| 红桃av成人在线观看| 日韩av有码一区二区三区4| 在线免费观看国产精品黄色| 国产成人精品福利短视频| 性生活第二下硬不起来| jiujiure精品视频在线| 丝袜肉丝一区二区三区四区在线| 免费69视频在线看| 日本特级片中文字幕| 极品粉嫩小泬白浆20p主播| 成人免费公开视频无毒 | 色偷偷伊人大杳蕉综合网| 久久这里只有精彩视频免费| 四川乱子伦视频国产vip| 动漫av网站18禁| 免费黄页网站4188| 日韩欧美中文国产在线| 99国内小视频在现欢看| 欧美乱妇无乱码一区二区| 黄色在线观看免费观看在线| 青青草亚洲国产精品视频| xxx日本hd高清| 欧美日本国产自视大全| 亚洲熟色妇av日韩熟色妇在线| 亚洲午夜在线视频福利| 岛国毛片视频免费在线观看| 熟女国产一区亚洲中文字幕| 在线制服丝袜中文字幕| 国产精品精品精品999| 五月色婷婷综合开心网4438| 成人高潮aa毛片免费| 人人妻人人人操人人人爽| 女同互舔一区二区三区| 热思思国产99re| 日本乱人一区二区三区| 亚洲图片偷拍自拍区| 日本韩国在线观看一区二区| 一级A一级a爰片免费免会员| av手机在线观播放网站| 天天色天天舔天天射天天爽| 绝顶痉挛大潮喷高潮无码| 国产91精品拍在线观看| 在线播放国产黄色av| 久久久久久久精品成人热| 天天干狠狠干天天操| 在线观看成人国产电影| 精品亚洲中文字幕av| 国产janese在线播放| 日本av高清免费网站| av成人在线观看一区| 91色网站免费在线观看| 国产亚洲欧美45p| 后入美女人妻高清在线| 又粗又硬又猛又爽又黄的| 任你操任你干精品在线视频| 肏插流水妹子在线乐播下载| 成人色综合中文字幕| 黄色片一级美女黄色片| 国产麻豆乱子伦午夜视频观看| 东游记中文字幕版哪里可以看到| 日本人竟这样玩学生妹| 一区二区免费高清黄色视频| 欧美久久一区二区伊人| 3344免费偷拍视频| 熟女在线视频一区二区三区| 91破解版永久免费| 国产女人露脸高潮对白视频| 婷婷午夜国产精品久久久| 老司机深夜免费福利视频在线观看 | 男人和女人激情视频| 亚洲高清自偷揄拍自拍| 亚洲一区二区三区精品视频在线| 一个色综合男人天堂| 午夜美女少妇福利视频| 五十路熟女人妻一区二区9933| 欧美成人猛片aaaaaaa| 一区二区在线视频中文字幕| 91‖亚洲‖国产熟女| 亚洲国产中文字幕啊啊啊不行了| 久久艹在线观看视频| 天天日天天干天天舔天天射| 久久机热/这里只有| 福利视频一区二区三区筱慧| 在线不卡日韩视频播放| av网址国产在线观看| 最新国产精品网址在线观看| 快插进小逼里大鸡吧视频| 和邻居少妇愉情中文字幕| 成人亚洲精品国产精品| 欧美交性又色又爽又黄麻豆| 午夜在线观看岛国av,com| 国产欧美精品一区二区高清| 国产又粗又黄又硬又爽| 专门看国产熟妇的网站| 国产精品久久久久久美女校花| av手机免费在线观看高潮| 日日操夜夜撸天天干| 国产揄拍高清国内精品对白| 51国产成人精品视频| 日本黄色三级高清视频| 亚洲成av人无码不卡影片一| 欧美成人精品在线观看| 爱有来生高清在线中文字幕| 丝袜美腿欧美另类 中文字幕| 久久久久久久一区二区三| 欧美综合婷婷欧美综合| 神马午夜在线观看视频| www天堂在线久久| 一色桃子人妻一区二区三区| 国产精品久久久久国产三级试频| 日韩人妻xxxxx| 青草青永久在线视频18| 成人国产小视频在线观看| 香蕉av影视在线观看| 欧美成一区二区三区四区| 国产av自拍偷拍盛宴| 亚洲欧美另类自拍偷拍色图| 欧美 亚洲 另类综合| 美日韩在线视频免费看| 国产福利小视频二区| 晚上一个人看操B片| 任我爽精品视频在线播放| 亚洲日本一区二区三区 | 天天通天天透天天插| 国产在线一区二区三区麻酥酥| 521精品视频在线观看| 五月天久久激情视频| 成人H精品动漫在线无码播放| 黑人进入丰满少妇视频| 欧美视频不卡一区四区| 成年人该看的视频黄免费| 亚洲精品午夜久久久久| 国产成人精品一区在线观看| 啊啊好慢点插舔我逼啊啊啊视频| 制丝袜业一区二区三区| 国内精品在线播放第一页| 日日夜夜大香蕉伊人| 熟女人妻一区二区精品视频| 国产成人精品福利短视频| 日韩剧情片电影在线收看| 中文字幕AV在线免费看 | 中文字幕亚洲中文字幕| 成熟丰满熟妇高潮xx×xx| 美女小视频网站在线| 欧美性感尤物人妻在线免费看| 麻豆性色视频在线观看| 免费在线观看污污视频网站| 久久精品视频一区二区三区四区| 蜜臀av久久久久久久| av天堂中文字幕最新| 98精产国品一二三产区区别| 最新激情中文字幕视频| 午夜毛片不卡在线看| 人人妻人人爽人人添夜| 精品亚洲国产中文自在线| 伊人成人在线综合网| 免费男阳茎伸入女阳道视频| 日韩北条麻妃一区在线| 亚洲天堂精品福利成人av| 男女啪啪视频免费在线观看| 国产精品国产三级麻豆| 99热99这里精品6国产| 国产精品国产三级国产午| 色天天天天射天天舔| 插逼视频双插洞国产操逼插洞| 中文字幕亚洲久久久| 少妇系列一区二区三区视频| 人妻少妇亚洲一区二区| 亚洲 国产 成人 在线| 动漫黑丝美女的鸡巴| 99精品视频在线观看免费播放 | 夜夜嗨av一区二区三区中文字幕| 18禁美女黄网站色大片下载| 国产成人精品av网站| 国产麻豆91在线视频| 中文字幕一区二区三区蜜月| 国产一线二线三线的区别在哪| 精品国产亚洲av一淫| 午夜精品一区二区三区4| 最新国产精品拍在线观看| 亚洲日本一区二区三区| 国产亚洲欧美另类在线观看| 欧美精品 日韩国产| 免费观看丰满少妇做受| 在线观看av观看av| 国产卡一卡二卡三乱码手机| 91精品国产高清自在线看香蕉网| 五月色婷婷综合开心网4438| 成人国产小视频在线观看| brazzers欧熟精品系列| 久久久久久久亚洲午夜综合福利 | 视频久久久久久久人妻| 男人的天堂av日韩亚洲| 亚洲国产欧美国产综合在线| 午夜激情久久不卡一区二区| 午夜国产福利在线观看| 国产精品一区二区av国| 自拍偷拍亚洲欧美在线视频| 日韩影片一区二区三区不卡免费| 午夜场射精嗯嗯啊啊视频| 中文字幕av熟女人妻| 18禁美女无遮挡免费| 欧美亚洲偷拍自拍色图| 少妇深喉口爆吞精韩国| 2022国产精品视频| 国产精品探花熟女在线观看| 午夜91一区二区三区| 中文字幕中文字幕人妻| 免费一级特黄特色大片在线观看| 中文字幕在线视频一区二区三区 | 激情伦理欧美日韩中文字幕| 中文字幕人妻一区二区视频 | japanese日本熟妇另类| 亚洲免费av在线视频| 老鸭窝在线观看一区| okirakuhuhu在线观看| 午夜福利人人妻人人澡人人爽| 韩国亚洲欧美超一级在线播放视频| 亚洲综合自拍视频一区| 精品久久久久久久久久中文蒉| 日本男女操逼视频免费看| 黄工厂精品视频在线观看| 91she九色精品国产| 中文字日产幕乱六区蜜桃| 人妻无码色噜噜狠狠狠狠色| 日视频免费在线观看| 亚洲av无女神免非久久| 日韩人妻xxxxx| 又黄又刺激的午夜小视频| 国产福利小视频免费观看| 亚洲卡1卡2卡三卡四老狼| 国产视频网站国产视频| 黄网十四区丁香社区激情五月天 | 成熟丰满熟妇高潮xx×xx| 五月天久久激情视频| 色婷婷精品大在线观看| 亚洲精品色在线观看视频| 韩国三级aaaaa高清视频 | 日韩不卡中文在线视频网站| 最新的中文字幕 亚洲| 在线观看视频网站麻豆| 91在线视频在线精品3| 经典av尤物一区二区| 啪啪啪啪啪啪啪啪av| 日本黄色特一级视频| 亚洲精品 日韩电影| 青青尤物在线观看视频网站| 免费高清自慰一区二区三区网站| 国产女孩喷水在线观看| 久久久久只精品国产三级| 欧美成人黄片一区二区三区| 天堂v男人视频在线观看| 中文字幕 码 在线视频| 91she九色精品国产| 在线成人日韩av电影| 天天躁日日躁狠狠躁躁欧美av| 天天日天天爽天天爽| 精品一区二区三区三区色爱| 一区二区三区精品日本| 无码中文字幕波多野不卡| 亚洲av色图18p| 水蜜桃一区二区三区在线观看视频| 午夜久久久久久久99| 成人久久精品一区二区三区| 精品美女在线观看视频在线观看| 国产激情av网站在线观看| 国产自拍在线观看成人| 人妻自拍视频中国大陆| 欧美va不卡视频在线观看| 大鸡吧插入女阴道黄色片| 中文字幕第三十八页久久| 中文字幕AV在线免费看 | 91免费观看国产免费| 亚洲高清视频在线不卡| 老师啊太大了啊啊啊尻视频| 中文字幕在线第一页成人| 11久久久久久久久久久| 免费大片在线观看视频网站| 国产密臀av一区二区三| 精品一线二线三线日本| 熟女视频一区,二区,三区| 又粗又长 明星操逼小视频 | 精品国产乱码一区二区三区乱| av网址在线播放大全| 国产一区二区视频观看| 亚洲一区二区三区五区| 非洲黑人一级特黄片| 午夜精品九一唐人麻豆嫩草成人| 黄色视频在线观看高清无码 | 色花堂在线av中文字幕九九 | 亚洲精品精品国产综合| 国产视频网站一区二区三区| 欧美一级片免费在线成人观看| 漂亮 人妻被中出中文| 久久综合老鸭窝色综合久久| 熟女国产一区亚洲中文字幕| 亚洲精品 欧美日韩| 天天色天天操天天透| 亚洲精品国产久久久久久| 老司机在线精品福利视频| 免费在线福利小视频| 精品一线二线三线日本| 偷拍自拍亚洲视频在线观看| 久久久极品久久蜜桃| 日本三极片视频网站观看| 美洲精品一二三产区区别| 午夜美女福利小视频| 日韩av中文在线免费观看| 成年人该看的视频黄免费| 亚洲一区二区三区五区| 91av精品视频在线| 狠狠操狠狠操免费视频| 日韩av中文在线免费观看| 中文字幕—97超碰网| 国产精品久久9999| 精品suv一区二区69| 亚洲国产欧美一区二区三区…| 亚洲一级av无码一级久久精品| 亚洲av色香蕉一区二区三区| 欧美老鸡巴日小嫩逼| 男人靠女人的逼视频| 99久久超碰人妻国产| AV天堂一区二区免费试看| 91精品国产综合久久久蜜| v888av在线观看视频| 青娱乐蜜桃臀av色| 在线播放 日韩 av| 天天做天天干天天操天天射| 在线免费观看靠比视频的网站| 国产精品黄片免费在线观看| 激情国产小视频在线| 亚洲 中文字幕在线 日韩| 337p日本大胆欧美人| 久久香蕉国产免费天天| 国语对白xxxx乱大交| 在线播放国产黄色av| 亚洲精品在线资源站| 99re6热在线精品| 日韩欧美国产一区ab| 中国熟女@视频91| 午夜极品美女福利视频| 国产av国片精品一区二区| 成年女人免费播放视频| 亚洲va国产va欧美va在线| 抽查舔水白紧大视频| 天天色天天舔天天射天天爽| 中文字幕+中文字幕| 中文字幕中文字幕 亚洲国产| 色偷偷伊人大杳蕉综合网| 久久免看30视频口爆视频| 精品久久久久久高潮| 国产午夜无码福利在线看| 最新国产精品拍在线观看| 好吊视频—区二区三区| 91九色porny蝌蚪国产成人| 日韩欧美在线观看不卡一区二区| av线天堂在线观看| 欧美在线一二三视频| 欧美一级色视频美日韩| 视频在线免费观看你懂得| 亚洲av无乱一区二区三区性色| 天天日天天爽天天爽| 欧美亚洲少妇福利视频| 91精品啪在线免费| 欧美一区二区三区高清不卡tv| 丰满的继坶3中文在线观看| 日日爽天天干夜夜操| 青青青爽视频在线播放| 伊人成人综合开心网| 亚洲av自拍天堂网| av天堂资源最新版在线看| 亚洲综合色在线免费观看| 99久久99一区二区三区| 啊啊啊想要被插进去视频| 91精品激情五月婷婷在线| av在线观看网址av| 特级无码毛片免费视频播放| japanese五十路熟女熟妇| 日本韩国免费福利精品| 北条麻妃肉色丝袜视频| 人人妻人人爽人人澡人人精品| 国产麻豆精品人妻av| 国产视频精品资源网站| 日韩黄色片在线观看网站| 超黄超污网站在线观看| 亚洲欧美色一区二区| 91综合久久亚洲综合| 人人妻人人爽人人添夜| 中字幕人妻熟女人妻a62v网| 天干天天天色天天日天天射| 美女福利写真在线观看视频| 一区二区三区美女毛片| 激情图片日韩欧美人妻| av中文字幕在线观看第三页| 中文字幕第一页国产在线| 青青青青视频在线播放| 中国黄色av一级片| 97精品视频在线观看| 青春草视频在线免费播放| 又粗又硬又猛又爽又黄的| 中国视频一区二区三区| 中文字幕乱码人妻电影| 桃色视频在线观看一区二区 | 国产日韩av一区二区在线| 888欧美视频在线| 亚洲午夜在线视频福利| 日本乱人一区二区三区| 伊人成人综合开心网| 亚洲精品国产久久久久久| 18禁网站一区二区三区四区 | 91亚洲手机在线视频播放| av亚洲中文天堂字幕网| 亚洲一区二区三区久久午夜 | 国产视频一区二区午夜| 午夜精品一区二区三区4| 欧美日韩高清午夜蜜桃大香蕉| 日曰摸日日碰夜夜爽歪歪| 97国产精品97久久| 东京热男人的av天堂| 中文字幕一区二区三区蜜月 | 日本阿v视频在线免费观看| 五十路av熟女松本翔子| 在线不卡成人黄色精品| 一区二区三区视频,福利一区二区 丰满的子国产在线观看 | 亚洲福利精品视频在线免费观看| 狠狠操操操操操操操操操| 免费在线福利小视频| 国产揄拍高清国内精品对白| 班长撕开乳罩揉我胸好爽| 欧美香蕉人妻精品一区二区| 极品性荡少妇一区二区色欲| 久久人人做人人妻人人玩精品vr | 久精品人妻一区二区三区| 四川乱子伦视频国产vip| 亚洲特黄aaaa片| 久草电影免费在线观看| 欧美日韩国产一区二区三区三州 | 青青青视频自偷自拍38碰| asmr福利视频在线观看| 天天日天天干天天干天天日| 1000部国产精品成人观看视频| 日本特级片中文字幕| 香蕉片在线观看av| 麻豆性色视频在线观看| 日本免费午夜视频网站| 在线亚洲天堂色播av电影| 青青青青操在线观看免费| 天天干天天啪天天舔| 成人av亚洲一区二区| 少妇系列一区二区三区视频| 欧美viboss性丰满| 国产成人精品午夜福利训2021| 欧美亚洲偷拍自拍色图| 亚洲女人的天堂av| av在线shipin| 亚洲av无码成人精品区辽| 中文字幕一区二区亚洲一区| 国产高清精品一区二区三区| 日韩av有码中文字幕| 一级黄片久久久久久久久| 国产露脸对白在线观看| 国产精品久久久久网| 丝袜肉丝一区二区三区四区在线看| 久久久久久性虐视频| 高清一区二区欧美系列| 天天日天天摸天天爱| 黄工厂精品视频在线观看| 78色精品一区二区三区| 成人高清在线观看视频| 97年大学生大白天操逼| 97色视频在线观看| 40道精品招牌菜特色| 亚洲中文字幕综合小综合| 成年人该看的视频黄免费| av大全在线播放免费| 欧美黑人性猛交xxxxⅹooo| 亚洲另类综合一区小说| 啪啪啪啪啪啪啪免费视频| 97青青青手机在线视频| 久久久制服丝袜中文字幕| 国产美女一区在线观看| 真实国产乱子伦一区二区| 伊人网中文字幕在线视频| 久久久久久久精品老熟妇| 91精品资源免费观看| 欧美成人黄片一区二区三区 | 国产美女午夜福利久久| 99精品国产aⅴ在线观看| 中文字幕午夜免费福利视频| 黑人3p华裔熟女普通话| 亚洲av香蕉一区区二区三区犇| 被大鸡吧操的好舒服视频免费| av男人天堂狠狠干| 日日夜夜精品一二三| 韩国亚洲欧美超一级在线播放视频 | 国产一级麻豆精品免费| 亚洲欧美福利在线观看| 一区二区三区av高清免费| 亚洲女人的天堂av| 性感美女诱惑福利视频| 色花堂在线av中文字幕九九| 9国产精品久久久久老师 | 亚洲欧美激情国产综合久久久| 国产清纯美女al在线| 99精品久久久久久久91蜜桃| 亚洲码av无色中文| 日韩黄色片在线观看网站| 91国内精品久久久久精品一| 天天干夜夜操天天舔| 2012中文字幕在线高清| 国产黄色片蝌蚪九色91| 免费费一级特黄真人片| 日本熟妇色熟妇在线观看| 国产精品系列在线观看一区二区| 国产高清女主播在线| 亚洲中文字幕国产日韩| 97人人模人人爽人人喊| 欧美一区二区三区高清不卡tv| 亚洲2021av天堂| 国产无遮挡裸体免费直播视频| 激情伦理欧美日韩中文字幕| 久久这里只有精彩视频免费| 狠狠鲁狠狠操天天晚上干干| 成人av免费不卡在线观看| 日韩成人免费电影二区| huangse网站在线观看| 狠狠躁夜夜躁人人爽天天久天啪| 天天做天天爽夜夜做少妇| 啊啊好慢点插舔我逼啊啊啊视频| 91国产在线视频免费观看| 男女啪啪啪啪啪的网站| 在线观看欧美黄片一区二区三区| 亚洲 欧美 精品 激情 偷拍| 久久人人做人人妻人人玩精品vr| 午夜成午夜成年片在线观看| av手机免费在线观看高潮| 欧美成人精品欧美一级黄色| 午夜精彩视频免费一区| 98精产国品一二三产区区别| 亚洲欧美激情国产综合久久久| 2020久久躁狠狠躁夜夜躁| 午夜美女福利小视频| 性欧美激情久久久久久久| 天美传媒mv视频在线观看| 亚洲码av无色中文| 亚洲美女美妇久久字幕组| 日韩无码国产精品强奸乱伦| 好男人视频在线免费观看网站| 中国产一级黄片免费视频播放| 国产视频网站一区二区三区| 亚洲av天堂在线播放| 哥哥姐姐综合激情小说| 久久久久久久99精品| 绯色av蜜臀vs少妇| 一区二区三区美女毛片| 亚洲另类综合一区小说| 天天干天天插天天谢| 成熟熟女国产精品一区| 亚洲 欧美 精品 激情 偷拍| 国产不卡av在线免费| 在线免费观看欧美小视频| 玩弄人妻熟妇性色av少妇| 亚洲码av无色中文| 欧美黑人性猛交xxxxⅹooo| 亚洲欧美激情国产综合久久久| 亚洲国产精品免费在线观看| 亚洲国产在人线放午夜| 日韩欧美制服诱惑一区在线| 国产福利小视频免费观看| 午夜精品一区二区三区4| 老司机欧美视频在线看| 大屁股肉感人妻中文字幕在线| 久久精品美女免费视频| 男人天堂最新地址av| brazzers欧熟精品系列| 午夜久久久久久久99| 亚洲av无乱一区二区三区性色| 最新激情中文字幕视频| 91精品国产麻豆国产| 超碰97人人做人人爱| 久久丁香花五月天色婷婷| 亚洲一区二区三区精品乱码| 男生舔女生逼逼的视频| 韩国爱爱视频中文字幕| 深夜男人福利在线观看| 青青色国产视频在线| 中文字幕亚洲中文字幕| 亚洲午夜高清在线观看| 红桃av成人在线观看| 五十路av熟女松本翔子| 性感美女诱惑福利视频| 国产精品手机在线看片| 亚洲欧美一区二区三区电影| 熟女少妇激情五十路| 中文字幕 人妻精品| 在线播放一区二区三区Av无码| 大陆精品一区二区三区久久| 天天日天天干天天搡| 亚洲无码一区在线影院| 久久久久久99国产精品| 国产污污污污网站在线| 大香蕉大香蕉在线看| 亚洲av自拍偷拍综合| 国产一级精品综合av| 熟女人妻在线观看视频| 国产第一美女一区二区三区四区| 国产av国片精品一区二区| 亚洲国产最大av综合| 欧美精品欧美极品欧美视频| 国产精彩福利精品视频| 亚洲免费国产在线日韩| 97精品成人一区二区三区 | 99久久激情婷婷综合五月天| 国产精品自拍在线视频| 中文字幕日韩精品日本| 国产不卡av在线免费| 久久机热/这里只有| 亚洲精品久久综合久| 亚洲av香蕉一区区二区三区犇| 操日韩美女视频在线免费看| 免费69视频在线看| nagger可以指黑人吗| av在线免费资源站| 高潮喷水在线视频观看| 91国产资源在线视频| 日韩亚洲高清在线观看| 亚洲女人的天堂av| 亚洲精品国产久久久久久| 日本福利午夜电影在线观看| 一级黄片久久久久久久久| 欧美成一区二区三区四区| 日本少妇的秘密免费视频| 91国产资源在线视频| 天天操天天污天天射| 日本美女成人在线视频| 老司机福利精品免费视频一区二区 | 视频久久久久久久人妻| 中文字幕高清免费在线人妻| 欧美偷拍亚洲一区二区| 韩国三级aaaaa高清视频| 玖玖一区二区在线观看| 日本精品视频不卡一二三| 91国内精品自线在拍白富美| 直接能看的国产av| 3D动漫精品啪啪一区二区下载| 成人免费做爰高潮视频| 91人妻精品一区二区久久| 亚洲av一妻不如妾| 欧美亚洲一二三区蜜臀| 国内资源最丰富的网站| 男人的天堂一区二区在线观看| av天堂中文免费在线| 人妻丝袜榨强中文字幕| 99久久久无码国产精品性出奶水| 福利一二三在线视频观看 | 1区2区3区不卡视频| 超碰在线观看免费在线观看| av完全免费在线观看av| 后入美女人妻高清在线| 亚洲国产在人线放午夜| 在线国产精品一区二区三区| 青青青视频自偷自拍38碰| 一二三区在线观看视频| 欧美一级色视频美日韩| 欧美美女人体视频一区| 777奇米久久精品一区| 国产极品精品免费视频| 日本免费一级黄色录像| 水蜜桃一区二区三区在线观看视频| 日本av高清免费网站| 四川五十路熟女av| 北条麻妃av在线免费观看| 国产黄色片在线收看| 青青操免费日综合视频观看| av在线免费观看亚洲天堂| 青春草视频在线免费播放| 亚洲欧美综合在线探花| 国产黑丝高跟鞋视频在线播放| 天天干天天操天天玩天天射| 狠狠嗨日韩综合久久| 含骚鸡巴玩逼逼视频| 区一区二区三国产中文字幕| 国产视频在线视频播放| 爱爱免费在线观看视频| 18禁无翼鸟成人在线| 亚洲欧美日韩视频免费观看| 欧美日本在线视频一区| 国产日韩欧美视频在线导航 | 免费观看国产综合视频| 秋霞午夜av福利经典影视| 青青草原色片网站在线观看| 同居了嫂子在线播高清中文| 欧美日韩亚洲国产无线码| 福利视频网久久91| 精品黑人一区二区三区久久国产| 成年女人免费播放视频| 国产av国片精品一区二区| 插逼视频双插洞国产操逼插洞| 91极品大一女神正在播放| 三上悠亚和黑人665番号| 欧美黑人性猛交xxxxⅹooo| 久久久久久久亚洲午夜综合福利| 国产熟妇乱妇熟色T区| 91精品国产综合久久久蜜| 亚洲 中文 自拍 另类 欧美| 色综合天天综合网国产成人| 丁香花免费在线观看中文字幕| 大香蕉日本伊人中文在线| 2019av在线视频| 欧美精品中文字幕久久二区| 久久香蕉国产免费天天| 婷婷六月天中文字幕| 天天日天天操天天摸天天舔| 色在线观看视频免费的| 直接观看免费黄网站| 国产露脸对白在线观看| 66久久久久久久久久久| 福利视频网久久91| 美日韩在线视频免费看| 激情色图一区二区三区| 亚洲高清国产拍青青草原| 大肉大捧一进一出好爽在线视频| av中文字幕国产在线观看| 99人妻视频免费在线| 日本三极片中文字幕| 午夜免费体验区在线观看| 欧美老妇精品另类不卡片| av中文字幕电影在线看| 99热久久这里只有精品| 成熟丰满熟妇高潮xx×xx| 日本特级片中文字幕| 亚洲美女高潮喷浆视频| 日韩欧美亚洲熟女人妻| 人人妻人人澡人人爽人人dvl| 成年女人免费播放视频| 内射久久久久综合网| 天天日夜夜干天天操| 亚洲欧美日韩视频免费观看| 日本少妇在线视频大香蕉在线观看 | 亚洲中文字幕人妻一区| 沈阳熟妇28厘米大战黑人| 人妻另类专区欧美制服| 九九视频在线精品播放| 男生舔女生逼逼的视频| av森泽佳奈在线观看| 久久久久久久久久性潮| 国产麻豆乱子伦午夜视频观看| 五十路老熟女码av| 香蕉91一区二区三区| 欧美成人精品在线观看| 亚洲人成精品久久久久久久| 欧洲黄页网免费观看| 成人性爱在线看四区| 国产一级精品综合av| 五月激情婷婷久久综合网| 久草视频首页在线观看| 男人插女人视频网站| 91老师蜜桃臀大屁股| 午夜精品福利91av| 亚洲人一区二区中文字幕| 亚洲图片欧美校园春色| 91极品新人『兔兔』精品新作| 亚洲成人激情视频免费观看了| 熟女妇女老妇一二三区| 日日操综合成人av| 国产亚洲国产av网站在线| 57pao国产一区二区| 97成人免费在线观看网站| 国产女人露脸高潮对白视频| 国产欧美日韩在线观看不卡| 国产成人精品一区在线观看| 青青草亚洲国产精品视频| 2020久久躁狠狠躁夜夜躁 | av日韩在线免费播放| 老司机在线精品福利视频| 在线观看黄色成年人网站| 青娱乐极品视频青青草| 性色蜜臀av一区二区三区| 天天日夜夜干天天操| 亚洲欧美国产麻豆综合| 首之国产AV医生和护士小芳| 天天干天天操天天插天天日| 亚洲 中文 自拍 另类 欧美| www骚国产精品视频| 黑人性生活视频免费看| 国产成人自拍视频播放| 国产高清女主播在线| 日视频免费在线观看| 很黄很污很色的午夜网站在线观看| 中文字幕人妻被公上司喝醉在线| 黄片三级三级三级在线观看| 亚洲精品 欧美日韩| 中国熟女@视频91| 欧美黄色录像免费看的| 青青青青草手机在线视频免费看| 欧美日本在线观看一区二区| 337p日本大胆欧美人| 成人在线欧美日韩国产| 青青青青青青青在线播放视频| 久久久麻豆精亚洲av麻花| 老司机在线精品福利视频| 五月天久久激情视频| 欧美视频不卡一区四区| 日本美女性生活一级片| japanese五十路熟女熟妇| 亚洲欧美激情中文字幕| 亚洲少妇高潮免费观看| 亚洲最大黄 嗯色 操 啊| 日本熟妇一区二区x x| 精品亚洲国产中文自在线| 亚洲黄色av网站免费播放| 好太好爽好想要免费| 1区2区3区4区视频在线观看| 99热久久这里只有精品| 亚洲蜜臀av一区二区三区九色| 边摸边做超爽毛片18禁色戒| av网站色偷偷婷婷网男人的天堂| 中文字幕一区二区三区蜜月| 日韩一区二区三区三州| 成熟熟女国产精品一区| 2017亚洲男人天堂| 午夜精品一区二区三区4| 日韩欧美亚洲熟女人妻| 最新国产精品拍在线观看| 亚洲成人黄色一区二区三区| 99热久久极品热亚洲| 亚洲乱码中文字幕在线| 福利视频网久久91| 午夜精品一区二区三区更新| 成人sm视频在线观看| 亚洲另类伦春色综合小| 亚洲视频乱码在线观看| 亚洲另类伦春色综合小| 全国亚洲男人的天堂| 中文字幕日韩人妻在线三区| brazzers欧熟精品系列| 国产一区二区欧美三区| 人人在线视频一区二区| 亚洲蜜臀av一区二区三区九色| 又大又湿又爽又紧A视频| 免费岛国喷水视频在线观看| 伊人综合aⅴ在线网| 中文字幕人妻被公上司喝醉在线| 免费观看成年人视频在线观看| 青青草国内在线视频精选| 日韩亚国产欧美三级涩爱| 国产精品自偷自拍啪啪啪| 黑人巨大精品欧美视频| 精品少妇一二三视频在线| 亚洲变态另类色图天堂网| 91大神福利视频网| 欧美一区二区三区在线资源 | 国产精品国产三级国产精东| 久青青草视频手机在线免费观看| 99精品视频在线观看婷婷| 久久这里只有精品热视频| 国产使劲操在线播放| www天堂在线久久| 小穴多水久久精品免费看| 婷婷久久久综合中文字幕| 天堂va蜜桃一区入口| 婷婷久久久综合中文字幕| 日韩二区视频一线天婷婷五| 午夜在线一区二区免费| 91传媒一区二区三区| 中文字幕视频一区二区在线观看| 熟女妇女老妇一二三区| 美女在线观看日本亚洲一区| 91人妻精品一区二区久久| 日本脱亚入欧是指什么| 久久久精品国产亚洲AV一| 激情图片日韩欧美人妻| 人妻无码中文字幕专区| 噜噜色噜噜噜久色超碰| 亚洲午夜电影在线观看| 国产janese在线播放| 亚洲av黄色在线网站| 久久久精品精品视频视频| 日韩中文字幕精品淫| 沙月文乃人妻侵犯中文字幕在线 | 午夜精品亚洲精品五月色| 又色又爽又黄又刺激av网站| 噜噜色噜噜噜久色超碰| 亚洲精品在线资源站| 天天通天天透天天插| 日韩中文字幕精品淫| 亚国产成人精品久久久| 国产清纯美女al在线| 精品人人人妻人人玩日产欧| 国产精品大陆在线2019不卡| 人妻熟女在线一区二区| 日韩美女福利视频网| 欧美一区二区三区高清不卡tv | 中文字幕人妻被公上司喝醉在线| 亚洲中文字幕综合小综合| 日韩人妻在线视频免费| 夜色撩人久久7777| 黑人大几巴狂插日本少妇| 插小穴高清无码中文字幕| 99的爱精品免费视频| 啪啪啪18禁一区二区三区| 黑人性生活视频免费看| 青青青青在线视频免费观看| 欧美精品激情在线最新观看视频| 亚洲欧美成人综合视频| 蜜桃视频在线欧美一区| 亚洲国产精品久久久久久6| 亚洲的电影一区二区三区 | 亚洲午夜电影在线观看| 久久丁香花五月天色婷婷| 91九色porny蝌蚪国产成人| 国产精品人久久久久久| 亚洲午夜高清在线观看| 只有精品亚洲视频在线观看| 最新日韩av传媒在线| 欧美精品久久久久久影院| 亚洲男人的天堂a在线| 馒头大胆亚洲一区二区| 一区二区三区欧美日韩高清播放| 小穴多水久久精品免费看| 欧美韩国日本国产亚洲| 成人av亚洲一区二区| 日本韩国亚洲综合日韩欧美国产| 日本真人性生活视频免费看| 肏插流水妹子在线乐播下载| 国产精品久久久黄网站| 亚洲一区二区三区在线高清| 欧美精品伦理三区四区| 99精品视频在线观看婷婷| 中文 成人 在线 视频| 久久久久只精品国产三级| 999九九久久久精品| 天天日天天添天天爽| 在线观看日韩激情视频| 国产剧情演绎系列丝袜高跟| 粉嫩av蜜乳av蜜臀| 桃色视频在线观看一区二区 | 天天躁日日躁狠狠躁av麻豆| 快插进小逼里大鸡吧视频| 国产成人无码精品久久久电影 | 5528327男人天堂| 日本最新一二三区不卡在线| 精品一线二线三线日本| 欧美在线偷拍视频免费看| 色呦呦视频在线观看视频| 欧美精产国品一二三产品区别大吗| 亚洲成人激情av在线| 玩弄人妻熟妇性色av少妇| 国产精品午夜国产小视频| 99精品国产aⅴ在线观看| 欧美日韩激情啪啪啪| 日本美女成人在线视频| 老师让我插进去69AV| 国产又粗又硬又大视频| 亚洲成人午夜电影在线观看| 亚洲熟色妇av日韩熟色妇在线| 青娱乐最新视频在线| 超鹏97历史在线观看| 欧美日韩激情啪啪啪| 最近中文2019年在线看| 加勒比视频在线免费观看| 天堂av在线官网中文| 国产在线观看黄色视频| 早川濑里奈av黑人番号| 色吉吉影音天天干天天操| 传媒在线播放国产精品一区| 玩弄人妻熟妇性色av少妇| 硬鸡巴动态操女人逼视频| 日本在线不卡免费视频| 欧美日韩一级黄片免费观看| 亚洲人妻av毛片在线| 55夜色66夜色国产精品站| 久久久噜噜噜久久熟女av| 国产三级影院在线观看| 亚洲 中文 自拍 无码| 色吉吉影音天天干天天操| 黄工厂精品视频在线观看| av网址国产在线观看| 熟女人妻在线中出观看完整版| 动色av一区二区三区|