【问题标题】:Calculate Maximum Length of MCrypt IV and Hash?计算 MCrypt IV 和哈希的最大长度?
【发布时间】:2014-06-02 15:06:45
【问题描述】:

我一直在对创建一些不同的哈希等进行一些研究。我知道password_hash() 函数,但是我目前正在使用 mcrypt 创建一个初始化值。出现的问题是,如果密码大于 8 个字符,一些散列密码会被截断。

我当前的代码在用户密码中添加了盐(由mcrypt_create_iv() 创建)。然后使用hash() 函数对其进行加密。 密码的标准是 8->40 个字符。

我在 MySQL 中的列看起来像使用 latin1_swedish_ci 排序规则的 varchar (64)。

如何计算初始化值的最大长度(MySQL 长度),以及用户输入密码的最大长度?

免责声明:我故意省略了加密,但会感谢任何有关不同密码块初始值长度和哈希长度的文档。 (不确定术语,希望有意义。)

【问题讨论】:

  • 这是散列,不是加密。加密不适用,因为加密不是一种方法(除非您丢失了密钥,在这种情况下它或多或少没用)。

标签: php hash cryptography mcrypt rijndael


【解决方案1】:

哈希函数以及password_hash() - 使用 HMAC 或加密 MAC 实现不同的基于密码的密钥派生函数 (PBKDF) - 对于任何输入值总是返回相同数量的数据。如果密码被截断,那是因为代码发生在之前任何这些函数被调用。如果您使用 SHA-1,这些函数通常会返回 20 个字节。

当然盐值也需要存储。

如果您使用十六进制存储它,那么与二进制值相比,您需要两倍的字符数。如果您使用 base 64 编码,如果您包含填充,则需要 ((size + 2) / 3 * 4) 字符。

因此,您的密码可以任意长或短,盐分每个字节占用一个字节(编码)。

强烈建议您还存储所用函数的某种指标。这可能是一个指示您当前协议的字节。这样,一旦用户返回填写他的(新)密码,您就可以升级每个条目的密码协议。

【讨论】:

  • 很好的答案!我调查了每一步计算长度的问题。发现某些字符被创建为多个字符“填充”字符串长度的问题。无论密码长度如何,哈希值和盐值都不会改变。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2014-02-24
  • 2019-03-18
  • 2011-04-06
  • 2012-06-13
相关资源
最近更新 更多