log*_*eks 6 c# hash 3des cryptography des
我有一个项目,规定了24字节数据块的以下加密规则.
1)密码学应使用9797-1中定义的全三重DES MAC算法作为MAC算法3进行,输出变换3没有截断,而CBC模式下的DES作为ICV设置为零的分组密码.最后8个字节的加密数据构成了我们需要的值.
该程序说加密完成是错误的.为了符合上述规格,我还需要做其他事吗?
数据是一个24字节的值,加密的输出应该是8个字节,我猜(根据规范).我得到整个24字节作为输出:(
我编写了以下代码来实现上述规范:
des.KeySize = 128;
des.Key = ParseHex(key);
des.Mode = CipherMode.CBC;
des.Padding = PaddingMode.None;
ICryptoTransform ic = des.CreateEncryptor();
CryptoOutput = ic.TransformFinalBlock(CryptoOutput, 0, 24);
Run Code Online (Sandbox Code Playgroud)
我也尝试了这个:
MACTripleDES des = new MACTripleDES(ParseHex(key));
byte[] CDCryptp = des.ComputeHash(CryptoOutput);
Run Code Online (Sandbox Code Playgroud)
ISO 9797-1 MAC 算法 3 包括使用第一个 DES 密钥来执行 CBC MAC,然后仅对最后一个块执行完整的 3-DES 操作。
尝试这个:
byte[] keybytes = ParseHex(key);
byte[] key1 = new byte[8];
Array.Copy(keybytes, 0, key1, 0, 8);
byte[] key2 = new byte[8];
Array.Copy(keybytes, 8, key2, 0, 8);
DES des1 = DES.Create();
des1.Key = key1;
des1.Mode = CipherMode.CBC;
des1.Padding = PaddingMode.None;
des1.IV = new byte[8];
DES des2 = DES.Create();
des2.Key = key2;
des2.Mode = CipherMode.CBC;
des2.Padding = PaddingMode.None;
des2.IV = new byte[8];
// MAC Algorithm 3
byte[] intermediate = des1.CreateEncryptor().TransformFinalBlock(data, 0, data.Length);
// Output Transformation 3
byte[] intermediate2 = des2.CreateDecryptor().TransformFinalBlock(intermediate, intermediate.Length - 8, 8);
byte[] result = des1.CreateEncryptor().TransformFinalBlock(intermediate2, 0, 8);
Run Code Online (Sandbox Code Playgroud)
djd*_*lib -2
这个问题的措辞可能没有应有的好,看起来很像家庭作业。因此,我将向您指出一些您可能还没有看到的链接,以便您可以学习。
其他人正在TripleDES 上执行 3DES MAC 值:指定的密钥是“TripleDES”的已知弱密钥,无法使用, 尽管我不建议像其中的一些答案那样改变 .NET 的行为。
如果您只需要使用 3DES,请查看:http://social.msdn.microsoft.com/Forums/en-US/csharpgeneral/thread/b9239824-e8a1-4955-9193-d9f6993703f3/
| 归档时间: |
|
| 查看次数: |
8338 次 |
| 最近记录: |