1

http://msdn.microsoft.com/en-us/library/system.security.cryptography.cryptostream.aspxから復号化コードを取得し、次のように変更しました。暗号化された例がありますが、デコード中は問題なく動作します。ただし、暗号化関数を使用すると、奇妙な記号を含むジャンク文字列が返されます。以下は暗号化/復号化の機能です。

暗号化された文字列"hey"の例: "??? U?b ??? z?Y ???"
再度デコードした場合:"ûc{ÁpÅ`ñ""Â"

私はこのコードを使用してバイト配列を文字列に変換しています:

private string ByteArrayToString(byte[] input)
    {
        ASCIIEncoding dec = new ASCIIEncoding();
        return dec.GetString(input);
    }

これが暗号化/復号化機能です。復号化機能は正常に機能しています。

private string DecryptStringFromBytesAes(byte[] cipherText, byte[] Key, byte[] IV)
    {
        // Check arguments. 
        if (cipherText == null || cipherText.Length <= 0)
            throw new ArgumentNullException("cipherText");
        if (Key == null || Key.Length <= 0)
            throw new ArgumentNullException("Key");

        // Declare the string used to hold 
        // the decrypted text.
        string plaintext = null;

        // Create an RijndaelManaged object 
        // with the specified key and IV. 
        using (RijndaelManaged aesAlg = new RijndaelManaged())
        {
            aesAlg.Key = Key;
            aesAlg.Padding = PaddingMode.Zeros;
            aesAlg.Mode = CipherMode.ECB;

            // Create a decrytor to perform the stream transform.
            ICryptoTransform decryptor = aesAlg.CreateDecryptor(aesAlg.Key, aesAlg.IV);

            // Create the streams used for decryption. 
            using (MemoryStream msDecrypt = new MemoryStream(cipherText))
            {
                using (CryptoStream csDecrypt = new CryptoStream(msDecrypt, decryptor, CryptoStreamMode.Read))
                {
                    using (StreamReader srDecrypt = new StreamReader(csDecrypt))
                    {

                        // Read the decrypted bytes from the decrypting stream 
                        // and place them in a string.
                        plaintext = srDecrypt.ReadToEnd();
                    }
                }
            }

        }

        return plaintext;

    }




private byte[] EncryptStringToBytesAes(string plainText, byte[] Key, byte[] IV)
    {
        // Check arguments. 
        if (plainText == null || plainText.Length <= 0)
            throw new ArgumentNullException("plainText");
        if (Key == null || Key.Length <= 0)
            throw new ArgumentNullException("Key");
        byte[] encrypted;
        // Create an RijndaelManaged object 
        // with the specified key and IV. 
        using (RijndaelManaged aesAlg = new RijndaelManaged())
        {
            aesAlg.Key = Key;
            aesAlg.Padding = PaddingMode.Zeros;
            aesAlg.Mode = CipherMode.ECB;
            // Create a decrytor to perform the stream transform.
            ICryptoTransform encryptor = aesAlg.CreateEncryptor(aesAlg.Key, aesAlg.IV);

            // Create the streams used for encryption. 
            using (MemoryStream msEncrypt = new MemoryStream())
            {
                using (CryptoStream csEncrypt = new CryptoStream(msEncrypt, encryptor, CryptoStreamMode.Write))
                {
                    using (StreamWriter swEncrypt = new StreamWriter(csEncrypt))
                    {

                        //Write all data to the stream.
                        swEncrypt.Write(plainText);
                    }
                    encrypted = msEncrypt.ToArray();
                }
            }
        }
        return encrypted;

    }
4

3 に答える 3

4

観察されるのは、任意のバイト(0〜255の範囲)を文字にマッピングする問題です。意味のある文字は、32〜255の範囲のみ、または32〜127(ASCII)のみです。32未満の値はいわゆる印刷不可能な文字であり、127を超える値は使用している文字エンコードによって異なります。そのため、暗号化されたテキストはジャンクのように見えます。したがって、マスト暗号システムはバイトを適切なASCII範囲に変換します。そのようなアルゴリズムの1つがBASE64です。したがって、暗号化されたバイトをBASE64で操作すると、すべて印刷可能で、電子メールで問題なく処理できる文字が得られます。復号化する前に、BASE64エンコーディングを元に戻す必要があります。

暗号化された結果の見栄えを良くする別の方法は、その16進表現を表示することです。たとえば、バイト値がある場合は、を出力し15ます0F。これを使用して、バイト配列を16進数で表すことができます。

private string ByteArrayToHexString(byte[] data)
{
    return String.Concat(data.Select(b => b.ToString("x2")));
}
于 2012-07-27T15:27:48.667 に答える
1

暗号化された文字列は文字化けのように見えます。暗号化が正しく機能しているかどうかをテストする方法は、文字列を復号化して戻すことです。復号化で機能する場合は、ごみのように見えても文字列が正しいことがわかります。

于 2012-07-27T15:23:19.977 に答える
1

データの16進エンコーディングとして出力を取得するには、ここにあるメソッドに従います。拡張メソッドになるように少し変更しました。

    public static string ToHexString(this byte[] bytes)
    {
        return bytes == null ? string.Empty : BitConverter.ToString(bytes).Replace("-", string.Empty);
    }

    public static byte[] FromHexString(this string hexString)
    {
        if (hexString == null)
        {
            return new byte[0];
        }

        var numberChars = hexString.Length;
        var bytes = new byte[numberChars / 2];

        for (var i = 0; i < numberChars; i += 2)
        {
            bytes[i / 2] = Convert.ToByte(hexString.Substring(i, 2), 16);
        }

        return bytes;
    }
于 2012-07-27T15:40:55.410 に答える