2

假设我编写了一个标准算法的实现,例如 MD* 或 SHA*:我怎么知道它是正确的?相同算法的不同实现必须产生相同的摘要?

4

2 回答 2

5

参考文档本身包含少量的示例案例,可以使用。(例如,所有参考文档中都有 的哈希值。)此外,Aaron Gifford 在http://www.adg.us/computers/sha.html"abc"上提供了许多测试用例。特别是,他对一些边界情况进行了测试(其中文本正好是块的长度,或者更少,以及其他一些特殊长度。如果您的实现为所有这些计算了正确的值,则有很有可能它是正确的。

于 2012-12-24T10:24:56.083 回答
3

是的,情况就是这样。但是,一些哈希算法带有变体/设置,因此如果是这种情况,您将需要匹配这些算法。

一个很好的例子是如何经常提供 MD5 以允许您验证您的下载是否正确。为了使其工作,MD5 哈希实现需要为所有实现产生相同的结果。

于 2012-12-24T10:17:09.777 回答