原文地址:
基于密码的身份认证包括了两个部分:
- 服务器端认证信息的存储
- 密码的认证过程
基于密码的身份认证有一个原则:仅使用人知道密码。密码不能被存储在认证服务器中,在认证过程中也不能通过网络明文传输。因为存储的信息可能被窃取或者滥用,网络可能被监听。这些安全隐患都可能导致密码的泄露。下面我们看看MySQL是如何做密码认证的。
MySQL中存储的认证信息
MySQL的mysql.user表中有password字段,其中存储的信息是用来做密码认证的。当查询这个字段时看到如下格式的字符串:
*0D3CED9BEC10A777AEC23CCC353A8C08A633045E
这个字符是什么呢?它是通过哈希算法SHA1计算出来的密码的哈希值。SHA1的哈希值长20字节,转换成十六进制的字符串长40字节。前面有一个固定的*总共占41字节。这个哈希值是调用两次SHA1哈希算法算出来的哈希值,代码中称为stage2hash。
stage2hash = sha1(sha1(密码))
从stage2hash是无法推导出密码的。即便这个哈希值被盗了,不知道用户的密码仍然无法认证成功。
MySQL的密码认证过程
MySQL的密码认证的安全性