如何在MySQL的`encrypt`函数中使用`bcrypt`算法来验证密码?

sec*_*tus 12 mysql encryption bcrypt

我有$2y$10$zQaDT8hXM4pLmBdwN0xEseda/oKJAQKMKMzUrV8jbs6Epz28BXzBS密码(qwe)的加密值().但是,当我验证我得到错误的结果哈希值.

mysql> select '$2y$10$zQaDT8hXM4pLmBdwN0xEseda/oKJAQKMKMzUrV8jbs6Epz28BXzBS' = encrypt('qwe', '$2y$10$zQaDT8hXM4pLmBdwN0xEseda/oKJAQKMKMzUrV8jbs6Epz28BXzBS') as is_valid; 
+----------+
| is_valid |
+----------+
|        0 |
+----------+

select encrypt('qwe', '$2y$10$zQaDT8hXM4pLmBdwN0xEseda/oKJAQKMKMzUrV8jbs6Epz28BXzBS') as hash;
+---------------+
| hash          |
+---------------+
| $2tBKnsbV2Szg |
+---------------+
Run Code Online (Sandbox Code Playgroud)

md5 工作良好

mysql> select '$1$$.dCRcHz4ApIYzcA0g/qz3/' = encrypt('qwe', '$1$$.dCRcHz4ApIYzcA0g/qz3/') as is_valid; 
+----------+
| is_valid |
+----------+
|        1 |
+----------+
Run Code Online (Sandbox Code Playgroud)

如何添加bcrypt对MySQL的支持?

dus*_*uff 20

你不能.MySQL ENCRYPT()函数使用操作系统的crypt()功能 - 如果您的操作系统不支持bcrypt哈希,MySQL也不支持它们.

另外,不要使用MySQL ENCRYPT()功能.正如ircmaxell所指出的,您传递给MySQL查询的任何数据都可能最终出现在服务器日志文件中,因此将其用于与密码相关的任何内容都可能是不安全的.

  • PHP 5.3及更高版本使用自己的`crypt()`实现,而不是来自操作系统的实现. (3认同)