如果我有IV,加密数据和结果值,我能找到Triple DES加密算法中的密钥吗?

时间:2011-10-10 06:51:09

标签: .net algorithm tripledes

这不适用于任何类型的黑客攻击,我只是尝试在.NET中使用Triple DES加密技术。我有一些测试数据。我必须得到给定数据的结果。我也有结果。但价值永远不会匹配。我确信代码很好(将在下面给出)。所以我认为唯一的可能是关键是错误的,所以让我们找到钥匙,看看是否匹配。以下是我的代码:

byte[] key = StringToByteArray("5b70649d4ae0bf2af891c167514aa7515b70649d4ae0bf2a");
byte[] iv = new byte[] { 0, 0, 0, 0, 0, 0, 0, 0 };
byte[] bytes = Encoding.ASCII.GetBytes("95e4d77c6d6c6c993333303533303833");
TripleDESCryptoServiceProvider tripleDes = new TripleDESCryptoServiceProvider();
tripleDes.Mode = CipherMode.CBC;
//tripleDes.Padding = PaddingMode.None;
tripleDes.Key = key;
tripleDes.IV = iv;
MemoryStream ms = new MemoryStream();
ICryptoTransform encryptor = tripleDes.CreateEncryptor();

CryptoStream cs = new CryptoStream(ms, encryptor, CryptoStreamMode.Write);
cs.Write(bytes, 0, bytes.Length);
cs.FlushFinalBlock();
byte[] cipher = ms.ToArray();
string finalValue = ByteToString(cipher, 16); //ByteToString method will convert byte array to string.

最终结果是1B529558534F43D15556AD65C7E396D5674EE8A09E0A29A84389020EF820AC51B7D5E1B33BDA18A2。 由于我只需要16个字节,因此我只将前16个字节转换为十六进制1B529558534F43D15556AD65C7E396D5

但预期结果为76db821f5c7af12dc8d70a6a79cfcb77 如果我能找到密钥,我可能知道密钥中也需要进行某种处理。

感谢您的帮助!

1 个答案:

答案 0 :(得分:1)

虽然它当然可能,但我不认为TripleDESCryptoServiceProvider类设计为“反向”工作,以便在拥有密码,IV和未加密数据时为您提供密钥。为什么要这样?