为什么“ $ 2a”和“ $ 2b”很重要?

时间:2019-01-10 19:22:02

标签: python bcrypt

我试图编写一个脚本来将用户添加到MySQL数据库中。最终,我将所有用户都带入了数据库,但是我的应用程序登录后并没有授权他们。我尝试了许多不同的解决方案,然后我发现老用户的密码以“ $ 2a”开头,而我添加的密码为“ $ 2b”。所以我在下面插入代码。

password = bcrypt.hashpw(password.encode("UTF-8"), bcrypt.gensalt(11))
password = password.decode("UTF-8")
password = password[:2] + "a" + password[3:] #Why does this work??

突然我可以登录了。那么,为什么拥有“ $ 2a”而不是“ $ 2b”呢?该网络应用不是我的,我无法在其中检查密码的代码中找到该应用。如果有帮助,则该webapp是用Java制作的,并使用spring进行了验证。

1 个答案:

答案 0 :(得分:2)

这里是Wikipedia on Bcrypt

  

$2$(1999)

     

原始的Bcrypt规范定义了$ 2 $的前缀。这遵循模块化地穴格式[...]

     

$2a$

     

原始规范没有定义如何处理非ASCII字符,也没有定义如何处理空终止符。对该规范进行了修改,以指定在对字符串进行哈希处理时:

     
      
  • 字符串必须为UTF-8编码
  •   
  • 必须包含空终止符
  •   
  • 通过此更改,版本已更改为$2a$
  •   
     

$2b$(2014年2月)

     

在bcrypt的OpenBSD实现中发现了一个错误。他们将字符串的长度存储在一个无符号字符(即8位字节)中。如果密码的长度超过255个字符,它将溢出并以255个换行。

您正在添加新格式,而该程序仅支持验证旧格式。

由于新旧格式都兼容<255个字符的密码,因此切换标头即可。但是,如果您尝试通过这种方式添加> = 256个字符的密码,则该密码将被视为无效。