我想使用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=");
答案 0 :(得分:2)
因为您没有设置密钥,所以每次调用方法时都会生成一个不同的密钥,因此您将获得不同的密文。您应该明确设置Key
属性,以便始终使用相同的密钥。