一段在asp中加密与解密对应的函数

  在ASP中加密方法有对应的解密方法好象不多,现在根据前辈资料整理出在asp中加密与解密函数

  rsa.asp

  <%

  rem 在ASP中实现加密与解密,加密方法:根据RSA

  rem 联系:[email protected]

  Class clsRSA

  Public PrivateKey

  Public PublicKey

  Public Modulus

  

  

  

  Public Function Crypt(pLngMessage, pLngKey)

    On Error Resume Next

    Dim lLngMod

    Dim lLngResult

    Dim lLngIndex

    If pLngKey Mod 2 = 0 Then

      lLngResult = 1

      For lLngIndex = 1 To pLngKey / 2

        lLngMod = (pLngMessage ^ 2) Mod Modulus

        ' Mod may error on key generation

        lLngResult = (lLngMod * lLngResult) Mod Modulus

        If Err Then Exit Function

      Next

    Else

      lLngResult = pLngMessage

      For lLngIndex = 1 To pLngKey / 2

        lLngMod = (pLngMessage ^ 2) Mod Modulus

        On Error Resume Next

        ' Mod may error on key generation

        lLngResult = (lLngMod * lLngResult) Mod Modulus

        If Err Then Exit Function

      Next

    End If

    Crypt = lLngResult

  End Function

  Public Function Encode(ByVal pStrMessage)

    Dim lLngIndex

    Dim lLngMaxIndex

    Dim lBytAscii

    Dim lLngEncrypted

    lLngMaxIndex = Len(pStrMessage)

    If lLngMaxIndex = 0 Then Exit Function

    For lLngIndex = 1 To lLngMaxIndex

      lBytAscii = Asc(Mid(pStrMessage, lLngIndex, 1))

      lLngEncrypted = Crypt(lBytAscii, PublicKey)

      Encode = Encode & NumberToHex(lLngEncrypted, 4)

    Next

  End Function

  

  Public Function Decode(ByVal pStrMessage)

    Dim lBytAscii

    Dim lLngIndex

    Dim lLngMaxIndex

    Dim lLngEncryptedData

    Decode = ""

    lLngMaxIndex = Len(pStrMessage)

    For lLngIndex = 1 To lLngMaxIndex Step 4

      lLngEncryptedData = HexToNumber(Mid(pStrMessage, lLngIndex, 4))

      lBytAscii = Crypt(lLngEncryptedData, PrivateKey)

      Decode = Decode & Chr(lBytAscii)

    Next

  End Function

  

  Private Function NumberToHex(ByRef pLngNumber, ByRef pLngLength)

    NumberToHex = Right(String(pLngLength, "0") & Hex(pLngNumber), pLngLength)

  End Function

  Private Function HexToNumber(ByRef pStrHex)

    HexToNumber = CLng("&h" & pStrHex)

  End Function

  End Class

  %>

  test.asp

  <!--#INCLUDE FILE="RSA.asp"-->

  <%

  function Encryptstr(Message)

  Dim LngKeyE

  Dim LngKeyD

  Dim LngKeyN

  Dim StrMessage

  Dim ObjRSA

  LngKeyE = "32823"

  LngKeyD = "20643"

  LngKeyN = "29893"

  StrMessage = Message

  

  Set ObjRSA = New clsRSA

  

   

      ObjRSA.PublicKey = LngKeyE

      ObjRSA.Modulus = LngKeyN

      Encryptstr = ObjRSA.Encode(StrMessage)

  Set ObjRSA = Nothing

  end function

  function decryptstr(Message)

  Dim LngKeyE

  Dim LngKeyD

  Dim LngKeyN

  Dim StrMessage

  Dim ObjRSA

  LngKeyE = "32823"

  LngKeyD = "20643"

  LngKeyN = "29893"

  StrMessage = Message

  

  Set ObjRSA = New clsRSA

      ObjRSA.PrivateKey =LngKeyD

      ObjRSA.Modulus=LngKeyN

      decryptstr=ObjRSA.Decode(StrMessage)

  Set ObjRSA = Nothing

  end function

  dim last,first

  first="sohu"

  Response.Write "加密前为:"&first

  last=Encryptstr(first)

  Response.Write "加密后为"&last

  Response.Write "解密后为" &decryptstr(last)

  %>