MD5散列如何不运行出散列?

How does MD5 hashing not run out of hashes?

如果我没记错的话,MD5 是一个 32 个字符长的散列。如果 MD5 只有 32 个字符长,而我们可以使字符串无限长,那么每个散列有何不同? MD5的上限是多少,到底是怎么完全不可预测的?

你错了,MD5是一种确定性的哈希算法,MD5中没有随机或随机化的东西。

当然,如果您将 MD5 应用于数据,则可能有其他数据生成相同的 MD5 值。这就是众所周知的碰撞。

MD5 与所有加密安全散列函数一样,不保证每个散列都不同,只是极不可能并且很难找到产生相同输出的两个输入。

MD5其实就是16个8位字节,128位。由于短输出(128 位)和一些内部问题,MD5 不再被认为足以满足大多数用途,通常 SHA-256 是一个很好的替代品。

你可以有碰撞。

两者:

  • d131dd02c5e6eec4693d9a0698aff95c 2fcab58712467eab4004583eb8fb7f89 55ad340609f4b30283e488832571415a 085125e8f7cdc99fd91dbdf280373c5b d8823e3156348f5bae6dacd436c919c6 dd53e2b487da03fd02396306d248cda0 e99f33420f577ee8ce54b67080a80d1e c69821bcb6a8839396f9652b6ff72a70
  • d131dd02c5e6eec4693d9a0698aff95c 2fcab50712467eab4004583eb8fb7f89 55ad340609f4b30283e4888325f1415a 085125e8f7cdc99fd91dbd7280373c5b d8823e3156348f5bae6dacd436c919c6 dd53e23487da03fd02396306d248cda0 e99f33420f577ee8ce54b67080280d1e c69821bcb6a8839396f965ab6ff72a70

给出相同的哈希值:

79054025255fb1a26e4bc422aef54eb4

每个散列都可能有冲突。只是发生这种情况的可能性有多大?

32-bit hashes have an even higher chance of colliding:

  • cataractperiti
  • 相撞
  • roquetteskivie
  • 相撞
  • shawlstormbound
  • 相撞
  • dowlasestramontane
  • 相撞
  • cricketingstwanger
  • 相撞
  • longanswhigs
  • 相撞