我正在尝试将一些现有的C++代码翻译成C#。我有一些代码在同一个HCRYPTHASH上调用CryptHashData 3次。文档中写道:“这个函数和CryptHashSessionKey可以被多次调用,以计算长数据流或不连续数据流的散列。”
这就是我想在C#中实现的。不幸的是,MD5.ComputeHash()似乎没有一种方法来构建现有的散列。
我是不是漏掉了什么,有没有C#应用程序接口可以做到这一点?
发布于 2010-10-07 15:15:03
实例化散列类的实例并使用TransformBlock和TransformFinalBlock
byte[] part1 = //...
byte[] part2 = //...
byte[] part3 = //...
var hash = new MD5CryptoServiceProvider();
hash.TransformBlock(part1, 0, part1.Length, null, 0);
hash.TransformBlock(part2, 0, part2.Length, null, 0);
hash.TransformFinalBlock(part3, 0, part3.Length);
byte[] res = hash.Hash;发布于 2010-10-07 12:49:32
C#中的密码功能是有限的。最好在C#中导入CryptoAPI。
[DllImport("Advapi32.dll", SetLastError=true)]
public static extern Boolean CryptHashData (
IntPtr hHash,
Byte[] pbData,
Int32 dwDataLen,
Int32 dwFlags
);查看this和this了解更多信息。
https://stackoverflow.com/questions/3878674
复制相似问题