2011-08-30 102 views
0

可以对此代码做什么以使用十六进制而不是ASCII进行加密?ASP.NET加密十六进制字符

加密:

Public Function EncryptAES(ByVal sIn As String, ByVal sKey As String) As String 
    Dim AES As New RijndaelManaged 
    Dim ahashMD5 As New MD5CryptoServiceProvider() 
    AES.Key = ahashMD5.ComputeHash(System.Text.ASCIIEncoding.ASCII.GetBytes(sKey)) 
    AES.Mode = CipherMode.ECB 
    Dim AESEncrypt As ICryptoTransform = AES.CreateEncryptor() 
    Dim aBuffer As Byte() = System.Text.ASCIIEncoding.ASCII.GetBytes(sIn) 
    Return Convert.ToBase64String(AESEncrypt.TransformFinalBlock(aBuffer, 0, aBuffer.Length)) 
End Function 

解密:

Public Function DecryptAES(ByVal sOut As String, ByVal sKey As String) As String 
    Dim dAES As New RijndaelManaged 
    Dim dahashMD5 As New MD5CryptoServiceProvider() 
    dAES.Key = dahashMD5.ComputeHash(System.Text.ASCIIEncoding.ASCII.GetBytes(sKey)) 
    dAES.Mode = CipherMode.ECB 
    Dim dAESDecrypt As ICryptoTransform = dAES.CreateDecryptor() 
    sOut = Replace(sOut, " ", "+", 1, -1, CompareMethod.Text) 
    Dim daBuffer As Byte() = Convert.FromBase64String(sOut) 
    Return System.Text.ASCIIEncoding.ASCII.GetString(dAESDecrypt.TransformFinalBlock(daBuffer, 0, daBuffer.Length)) 
End Function 

回答

0

可能有这样做的更简洁的方法,但类似下面应该助阵:

Dim i = 0 
Dim result = String.Empty 
Dim bytes = ..a byte array containing the hashed bytes... 
For i As Integer = 0 to bytes.Length 
    result += String.Format("{0:x2}", bytes(i)) 
Next 

所以,而不是在将字节转换为字符串时使用Return的最后一行使用这种方法并使用Return result

+0

这究竟在哪里适合上面的代码? –

+0

对于两者,或只是加密/解密? –

+0

无论你想返回一个十六进制字符串中的字节。 –