AES字符串加密/解密字符间隔开

时间:2011-10-04 09:41:07

标签: c# encryption character-encoding aes

我正在使用AES加密然后解密字符串。但我的输出看起来像这样:

Original text >> HI WORLD  
Decrypted text >> H I   W O R L D

我尝试了很多代码,但我没有发现问题。

这里的问题在哪里?

class Program
{
    public static void Main(string[] args)
    {
        byte[] aesKey = Cryptography.GenerateAes128Key();
        Console.WriteLine("AES key >> " + aesKey.Length);
        string originalText = "HI WORLD";
        byte[] myMess = ASCIIEncoding.Unicode.GetBytes(originalText);
        Console.WriteLine("Original text >> " + ASCIIEncoding.Unicode.GetString(myMess));
        byte[] myEcnryptedMess = Cryptography.Encrypt(myMess, aesKey);
        Console.WriteLine("Encrypted text >> " + ASCIIEncoding.Unicode.GetString(myEcnryptedMess));
        Console.WriteLine("Decrypted text >> " + Cryptography.Decrypt(myEcnryptedMess, aesKey));
        Console.WriteLine("Press any key to continue . . . ");
        Console.ReadKey(true);
    }

    public static byte[] Encrypt(byte[] plainTextBytes, byte[] Key)
    {
        byte[] iv = new byte[Key.Length];
        Aes myAes = Aes.Create();
        ICryptoTransform encryptor = myAes.CreateEncryptor(Key, iv);
        MemoryStream memoryStream = new MemoryStream();
        CryptoStream cryptoStream = new CryptoStream(memoryStream, encryptor, CryptoStreamMode.Write);
        cryptoStream.Write(plainTextBytes, 0, plainTextBytes.Length);
        cryptoStream.FlushFinalBlock();
        byte[] cipherTextBytes = memoryStream.ToArray();
        // Close both streams.
        memoryStream.Close();
        cryptoStream.Close();
        return cipherTextBytes;
    }

    public static string Decrypt(byte[] cipherTextBytes, byte[] Key)
    {
        byte[] iv = new byte[Key.Length];
        Aes myAes = Aes.Create();
        ICryptoTransform decryptor = myAes.CreateDecryptor(Key, iv);
        MemoryStream  memoryStream = new MemoryStream(cipherTextBytes);
        CryptoStream  cryptoStream = new CryptoStream(memoryStream, decryptor, CryptoStreamMode.Read);
        byte[] plainTextBytes = new byte[cipherTextBytes.Length];
        // Start decrypting.
        int decryptedByteCount = cryptoStream.Read(plainTextBytes, 0, plainTextBytes.Length);
        // Close both streams.
        memoryStream.Close();
        cryptoStream.Close();
        // Convert decrypted data into a string.
        // Let us assume that the original plaintext string was UTF8-encoded.
        string plainText = Encoding.UTF8.GetString(plainTextBytes, 0, decryptedByteCount);
        // Return decrypted string.
        return plainText;
    }
}

2 个答案:

答案 0 :(得分:3)

您正在使用不同的编码来GetBytes和GetString:

ASCIIEncoding.Unicode.GetBytes(originalText);

然后

Encoding.UTF8.GetString(plainTextBytes, 0, decryptedByteCount)

尝试对两个操作使用相同的操作。

克里斯

答案 1 :(得分:1)

你正在搞乱你的字符串编码。 ASCIIEncoding.Unicode基本上是胡说八道。 (实际上,它与Encoding.Unicode一样,但是以误导的方式写出来。)

您想使用哪种编码? UTF-16,UTF-8还是ASCII?根据选择,使用Encoding.UnicodeEncoding.UTF8Encoding.ASCII,并坚持下去。我认为UTF-8是最好的选择,因此,请使用:

// ...
string originalText = "HI WORLD";
byte[] myMess = Encoding.UTF8.GetBytes(originalText);
Console.WriteLine("Original text >> " + Encoding.UTF8.GetString(myMess));
byte[] myEcnryptedMess = Cryptography.Encrypt(myMess, aesKey);
Console.WriteLine("Encrypted text >> " + Encoding.UTF8.GetString(myEcnryptedMess));
Console.WriteLine("Decrypted text >> " + Cryptography.Decrypt(myEcnryptedMess, aesKey));