为什么每次从RijndaelManaged返回的密文不同?

时间:2015-05-21 23:37:43

标签: c# .net encryption rijndaelmanaged

我想使用RijndaelManaged加密任何salting的字符串,所以如果我使用相同的密钥加密字符串,我将收到相同的密文。 我调用的方法看起来像这样

     public static string GetEncryptedData(string plainText)
    {
        var cipher = new RijndaelManaged();

        string keyString = "really long string"

        var key = Encoding.UTF8.GetBytes(keyString);
        cipher.Padding = PaddingMode.Zeros;
        cipher.Mode = CipherMode.ECB;
        cipher.KeySize = 256;
        cipher.BlockSize = 256;

        var cryptoTransform = cipher.CreateEncryptor();
        byte[] stuffToEncrypt = Encoding.UTF8.GetBytes(plainText);
        byte[] cipherText = cryptoTransform.TransformFinalBlock(stuffToEncrypt, 0, plainText.Length);

        return Convert.ToBase64String(cipherText);
    }

我想如果我设置

cipher.Padding = PaddingMode.Zeros;
cipher.Mode = CipherMode.ECB;

没有引入随机性,每次使用相同的输入调用此方法时结果都是相同的

GetEncryptedData("somestring")

但每次运行时都会返回diff值。我错过了什么?

修改

正如所接受的答案所指出的那样,我忘了设置密钥,所以添加这个就行了

cipher.Key = Convert.FromBase64String("C53wafJw3QmImGBN8Se9EnIJgiQq7LyoWHzUEFQI/B0=");

1 个答案:

答案 0 :(得分:2)

因为您没有设置密钥,所以每次调用方法时都会生成一个不同的密钥,因此您将获得不同的密文。您应该明确设置Key属性,以便始终使用相同的密钥。