这个问题说明了一切。这段代码
string hash = "";
using (var md5 = System.Security.Cryptography.MD5.Create())
{
hash = Convert.ToBase64String(md5.ComputeHash(streamReader.BaseStream));
}
将始终返回相同的哈希。
如果我将 BaseStream 中的所有数据传递到 MemoryStream 中,它每次都会给出一个唯一的哈希值。跑步也是一样
string hash = "";
using (var md5 = System.Security.Cryptography.MD5.Create())
{
hash = Convert.ToBase64String(md5.ComputeHash(
Encoding.ASCII.GetBytes(streamReader.ReadToEnd())));
}
第二个实际上更快,但我听说这是不好的做法。
我的问题是,使用 ComputeHash(stream) 的正确方法是什么。对我来说,它总是(我的意思是总是,即使我重新启动程序,这意味着它不仅仅是散列引用)返回相同的散列,无论流中的数据如何。