-1

这并不意味着任何类型的黑客攻击,我只是在尝试使用 .NET 中的三重 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 个字节转换为 hex 1B529558534F43D15556AD65C7E396D5

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

谢谢您的帮助!

4

1 回答 1

1

虽然它肯定是可能的,但我认为 TripleDESCryptoServiceProvider 类并非旨在“反向”工作,以便在您拥有密码、IV 和未加密数据时为您提供密钥。为什么要呢?

于 2011-10-10T07:38:48.030 回答